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1 Introduction 
1.1 Overview 


This specification defines the functional behavior and software interface of the Advanced Host Controller 
Interface, which is a hardware mechanism that allows software to communicate with Serial ATA devices. 
AHCI is a PCI class device that acts as a data movement engine between system memory and Serial 
ATA devices. 


AHCI host devices (referred to as host bus adapters, or HBA) support from 1 to 32 ports. An HBA must 
support ATA and ATAPI devices, and must support both the PIO and DMA protocols. An HBA may 
optionally support a command list on each port for overhead reduction, and to support Serial ATA Native 
Command Queuing via the FPDMA Queued Command protocol for each device of up to 32 entries. An 
HBA may optionally support 64-bit addressing. 


AHCI describes a system memory structure which contains a generic area for control and status, and a 
table of entries describing a command list (an HBA which does not support a command list shall have a 
depth of one for this table). Each command list entry contains information necessary to program an 
SATA device, and a pointer to a descriptor table for transferring data between system memory and the 
device. 


1.2 Scope 


AHCI encompasses a PCI device. It contains a PCI BAR (Base Address Register) to implement native 
SATA features. AHCI specifies the following features: 


Support for 32 ports 

Elimination of Master / Slave Handling 
Hot Plug 

HW Assisted Native Command Queuing 
Cold device presence detect 

Activity LED generation 


1.3. Outside of Scope 


AHCI does not contain information relevant to implementing the Transport, Link or Phy layers of Serial 
ATA as this is wholly described in the Serial ATA 1.0a specification. 


64-bit addressing 

Large LBA support 

Power Management 
Staggered Spin-up 

Serial ATA superset registers 
Port Multiplier 


AHCI does not specify ATA legacy behavior, such as the legacy I/O ranges, or Bus Master IDE. 
Allowances have been made in AHCI so that an HBA may implement these features for backward 
compatibility with older operating systems (for example, the location of the memory BAR for AHCI is after 
the BAR locations for both native IDE and bus master IDE). 


1.4 Block Diagram 


In Figure 1, several AHCI HBAs are attached in a typical computer system. One HBA is integrated in the 
core chipset. Another sits off the first available PCI/PCI-X bus. (PCI is used as a reference name. The 
bus can be any PCl-like bus, such as PCI-X, PCI-Express, HyperTransport, etc.) The intent is to be 
compliant with the PCI base specification. Compliance with non-PCl specifications is dependant upon 
those specifications being compliant/compatible with PCI. 


A final HBA sits off a second PCI bus that exists behind a PCI-PCI bridge. This last HBA has one port 
attached to a Port Multiplier 
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Figure 1: IA Based System Diagram 
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In Figure 2, two HBA are connected to an embedded CPU with its own local memory. This configuration 
would most likely be used in a RAID-type environment. 


Figure 2: Embedded System Diagram 
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1.5 Conventions 


Hardware must return ‘0’ for all bits and registers that are marked as reserved, and software must write all 
reserved bits and registers with the value of ‘0’. 


Inside the register section, the following abbreviations are used: 


RO Read Only 
RW Read Write 
RWC Read/Write ‘1’ to clear 
RW1 Read/Write ‘1’ to set 
Impl. Spec. Implementation Specific — the HBA has the freedom to choose its 
implementation. 
Hwinit The default state is dependent on device and system configuration. 
The value is initialized at reset, either by an expansion ROM, or in the 
case of integrated devices, by a platform BIOS. 


When a register bit is referred to in the document, the convention used is “Register Symbol.Field Symbol’. 
For example, the configuration space PCI command register parity error response bit is referred to by the 
name CMD.PEE. If the register field is an array of bits, the field will be referred to as “Register 
Symbol.Field Symbol(array offset)”. 

When a memory field is referred to in the document, the convention used is “Register Name[Offset 
Symbol]’. For example, the pointer to the Command Header of port 0 is referred to by the name 
POCLB[CHO]. 
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1.6 Definitions 
1.6.1 command list 


Defines commands located in system memory that an HBA processes. This is a list that may contain 1 to 
32 entries (called command slots), and may contain any type of ATA or ATAPI command. The command 
list is advanced when the BSY, DRQ, and ERR bits of a Serial ATA device is cleared. 


1.6.2 command slot 


A command slot is one of the entries in the command list. The command slot contains the command to 
execute. Up to 32 slots (i.e. entries) are supported in a command list. 


1.6.3 cs 
cs is used to describe fields that have a command specific meaning. 
1.6.4 D2H 


D2H is an acronym for “device to HBA”. In the Serial ATA specifications, this acronym stands similarly for 
“device to host”. D2H is often used to describe the direction of transfer for a FIS. 


1.6.5 device 


A physical device, such as a hard disk drive (HDD) or an optical disk drive (ODD) that is either directly 
attached to an HBA port, or is attached through a Port Multiplier to an HBA port. 


1.6.6 FIS 


FIS is an acronym for “Frame Information Structure”. A FIS is a packet or frame of information that is 
transferred between the host and device. Refer to the Serial ATA 1.0a specification for more information. 


1.6.7. H2D 


H2D is an acronym for “HBA to device”. In the Serial ATA specifications, this acronym stands similarly for 
“host to device”. H2D is often used to describe the direction of transfer for a FIS. 


1.6.8 HBA 


HBA is an acronym for “host bus adapter’. A host bus adapter refers to the silicon that implements the 
AHCI specification to communicate between system memory and Serial ATA devices. 


1.6.9 nia 
n/a is used to describe fields that are not applicable or unused for a particular command. 
1.6.10 port 


A physical port on the HBA, with a set of registers that control the DMA and link operations. A physical 
port may have several devices attached to it via a Port Multiplier. 


1.6.11 PRD 


PRD is an acronym for “physical region descriptor’. PRD entries describe the physical location and 
length of data to be transferred. Refer to section 4.2.3.3. 


1.6.12 queue 


Indicates the ATA command queue inside a Serial ATA device. This is differentiated from the command 
list in that a queue shall only exist in a Serial ATA device when all the commands in the HBA’s command 
list are Serial ATA native queuing commands. 


1.6.13 register memory 


Registers allocated in the memory space of the HBA. These registers are physically implemented in the 
HBA. 
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1.6.14 system memory 


DRAM or “main” memory of a computer system, used to communicate data and command information 
between the host processor and the Serial ATA device. 


1.7 Theory of Operation 


AHCI takes the basics of the scatter/gather list concept of Bus Master IDE, and expand it to reduce 
CPU/software overhead and provide support for Serial ATA features such as hot plug, power 
management, and accessing of several devices without performing master/slave emulation. 


Communication between a device and software moves from the task file via byte-wide accesses to a 
command FIS located in system memory that is fetched by the HBA. This reduces command setup time 
significantly, allowing for many more devices to be added to a single host controller. Software no longer 
communicates directly to a device via the task file. 


AHCI is defined to keep the HBA relatively simple so that it can act as a data mover. An HBA 
implementing AHCI is not required to parse any of the ATA or ATAPI commands as they are transferred 
to the device, although it is not prohibited from doing so. 


All data transfers between the device and system memory occur through the HBA acting as a bus master 
to system memory. Whether the transaction is of a DMA type or a PIO type, the HBA fetches and stores 
data to memory, offloading the CPU. There is no accessible data port. 


All transfers are performed using DMA. The use of the PIO command type is strongly discouraged. PIO 
has limited support for errors — for example, the ending status field of a PIO transfer is given to the HBA 
during the PIO Setup FIS, before the data is transferred. However, some commands may only be 
performed via PIO commands (such as IDENTIFY DEVICE). Some HBA implementations may limit PIO 
support to one DRQ block of data per command. 


The AHCI defines a standard mechanism for implementing a SATA command queue using the DMA 
Setup FIS. An HBA which supports queuing has individual slots in the Command List allocated in 
system memory for all the commands. Software can place a command into any empty slot, and upon 
notifying the HBA via a register access, the HBA shall fetch the command and transfer it. The tag that is 
returned in the DMA Setup FIS is used as an index into the command list to get the scatter/gather list 
used in the transfer. 


This command list can be used by system software and the HBA even when non-queued commands 
need to be transferred. System software can still place multiple commands in the list, whether DMA, PIO, 
or ATAPI, and the HBA will walk the list transferring them. 


This multiple-use of the command list is achieved by the HBA only moving its command list pointer when 
the BSY, DRQ, and ERR bits are cleared by the device. System software is responsible to ensure that 
queued and non-queued commands are not mixed in the command list. 


1.8 Interaction with Legacy Software 


AHCI is a self-contained specification that is intended to support all aspects of communicating with SATA 
devices, without having to utilize any legacy features such as shadow copies of the task file, snooping of 
bits in commands, etc. 


HBAs that support legacy software mechanisms must do so in a fashion that is transparent to AHCI. 
Legacy registers are not allowed to affect any bits in AHCI registers, nor is AHCI software allowed to 
affect any bits in legacy registers. Software written for AHCI is not allowed to utilize any of the legacy 
mechanisms to program devices. In essence, an HBA that supports both mechanisms must isolate its 
legacy and AHCI engines, as shown in Figure 3. 
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Figure 3: Example of HBA Silicon Supporting Both Legacy and AHCI Interfaces 
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How an HBA running legacy software supports more than 4 ports is beyond the scope of this 
specification. How software transitions between legacy and AHCI modes of operation is beyond the 
scope of this specification. 


1.9 References 


The AHCI utilizes the following documents as references: 
PCI Specification, Revision 3.0 
co http://www.pcisig.com 
PCI Power Management Specification 
co http://www.pcisig.com 
ATA/ATAPI-7 
o  http://www.t13.org 
Serial ATA 1.0a, Serial ATA Il: Extensions to Serial ATA 1.0a revision 1.2, Serial ATA II: Port 
Multiplier revision 1.1, Serial ATA Il: Port Selector revision 1.0 
o  http://www.serialata.org 
Microsoft's Storage Device Class Power Management Specification: 
o http://www. microsoft.com/hwdev/resources/specs/pmref/default.asp 
SAF-TE — SCSI Accessed Fault-Tolerant Enclosure version 1.00 [revision R041497, April 14, 1997]. 


ANSI INCITS 305-1998, Information Technology — SCSI-3 Enclosure Services (SES) Command Set: 
o  http://webstore.ansi.org or http://www.t10.org 


SGPIO — SFF-8485 Specification for Serial GPIO 
o http://www.sffcommittee.org 
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2 HBA Configuration Registers 
This section details how the PCI Header and PCI Capabilities should be constructed for an AHCI HBA. 


The fields shown are duplicated from the appropriate PCI specifications. 


The PCI documents are the 


normative specifications for these registers and this section details additional requirements for an AHCI 


HBA. 


2.1 


Start (hex) | End(hex) [Name OSO—SSCSCSCSCCCTCCC*d 
| 00 | F__| PCI Header 
PMCAP PMCAP+7 | PCI Power Management Capability 
MSICAP MSICAP+9 | Message Signaled Interrupt Capability 
PCI Header 


CC 
CLS 


Interrupt Information 
3E 3E MGNT Min Grant (Optional) 
3F 3F MLAT Max Latency (Optional) 
2.1.1 Offset 00h: ID - Identifiers 
Bits Type | Reset | Description 
31:16 RO ene Device ID (DID): Indicates what device number assigned by the vendor. 
: Impl. | Vendor ID (VID): 16-bit field which indicates the company vendor, assigned by the PCI 
15:00 RO 
Spec. | SIG. 
2.1.2 Offset 04h: CMD - Command 
Bit Type Reset | Description 


15:11 | RO | 0 | Reserved 


Interrupt Disable (ID): Disables the HBA from generating interrupts. This bit does not 
10 RW 0 : 

have any effect on MSI operation. 

Fast Back-to-Back Enable (FBE): When set to ‘1’, the HBA is allowed to generate fast 
09 RW/RO 0 : . 

back-to-back cycles to different devices. 
08 RW/RO 0 SERR# Enable (SEE): When set to ‘1’, the HBA is allowed to generate SERR# on any 

event that is enabled for SERR# generation. When cleared to ‘0’, it is not. 
07 RO @) Wait Cycle Enable (WCC): Reserved. 

Parity Error Response Enable (PEE): When set to ‘1’, the HBA shall generate PERR# 
06 RW/RO 0 ; : 

when a data parity error is detected. 
05 RO 0 VGA Palette Snooping Enable (VGA): Reserved 

mel Memory Write and Invalidate Enable (MWIE): When set to ‘1’, the HBA is allowed to 
04 RW/RO Ss ise use the memory write and invalidate command. This feature is not necessary if the 
P controller does not generate this command. 

03 RO 0 Special Cycle Enable (SCE): Reserved 


Revision 1_1.doc Serial ATA AHCI 1.1 Specification 


Bus Master Enable (BME): Controls the HBA’s ability to act as a master for data 

02 RW transfers. When set to ‘1’, bus master activity is allowed. When cleared to ‘0’, the HBA 
stops and any active DMA engines return to an idle condition. It is the equivalent of 
clearing the memory space start bits (PxCMD.ST) in each port. 


| 01 | RW | 0 [| Memory Space Enable (MSE): Controls access to the HBA’s register memory space. 
RW/ Impl I/O Space Enable (IOSE): Controls access to the HBA’s target I/O space. If the HBA 
RO Spec also supports bus master IDE, this bit must be read/write. This bit should be read-only 
if bus master IDE is not supported by the HBA. 


2.1.3 Offset 06h: STS - Device Status 


Bit Type Description 
Detected Parity Error (DPE): Set to ‘1’ by hardware when the HBA detects a parity 
15 RWC ag 
error on its interface. 
Signaled System Error (SSE): Set to ‘1’ by hardware when the HBA host generates 
14 RWC SERR# 


Received Master-Abort (RMA): Set to ‘1’ by hardware when the HBA receives a 


13 RWC : 

master abort to a cycle it generated. 

Received Target Abort (RTA): Set to ‘1’ by hardware when the HBA receives a target 
12 RWC : 

abort to a cycle it generated. 

Signaled Target-Abort (STA): Set to ‘1’ by hardware when the HBA terminates with a 
11 RWC 

target abort. 

10:09 RO DEVSEL# Timing (DEVT): Controls the device select time for the HBA’s PCI interface. 
: . | Refer to the PCI specification for further details. 

Master Data Pariy Error Detected (DPD): Set to ‘1’ by hardware when the HBA, as a 

08 RWC master, either detects a parity error or sees the parity error line asserted, and the parity 


error response bit (bit 6 of the command register) is set to ‘1’. 
07 RO Impl. | Fast Back-to-Back Capable (FBC): Indicates whether the HBA can accept fast back- 
Spec. | to-back cycles. 


06_| RO | 0 | Reserved 


05 RO “| 66 MHz Capable (C66): Indicates whether the HBA can operate at 66 MHz. 


Capabilities List (CL): Indicates the presence of a capabilities list. The HBA must 
04 RO i ras 
support the PCI power management capability as a minimum. 


03 RO Interrupt Status (IS): Indicates the interrupt status of the device (1 = asserted). 
02:00 | _RO 


2.1.4 Offset 08h: RID - Revision ID 


Bits Type | Reset | Description 
07:00 RO 00h Revision ID (RID): Indicates stepping of the HBA hardware. 


2.1.5 Offset 09h: CC - Class Code 


Bits Type | Reset | Description 
23:16 RO 01h Base Class Code (BCC): Indicates that this is a mass storage device. 


15:08 RO Impl Sub Class Code (SCC): When set to 06h, indicates that this is a Serial ATA device. 


Spec 
imol Programming Interface (PI): When set to 01h and the Sub Class Code is set to 06h, 
07:00 RO Ss p indicates that this is an AHCI HBA that has a major revision of 1 (as specified in the 
pec : f 
AHCI Version register). 


Informative Note: For HBAs that support RAID, the Sub Class Code reset value should be 04h and the 
Programming Interface reset value should be 00h. 


2.1.6 Offset OCh: CLS — Cache Line Size 


Bits Type | Reset | Description 

Cache Line Size (CLS): Indicates the cache line size for use with the memory write 
07:00 RW 00h and invalidate command, and as an indication on when to use the memory read 
multiple, memory read line, or memory read commands. 
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2.1.7 Offset ODh: MLT — Master Latency Timer 


Bits Type | Reset | Description 
07:00 RW 00h Master Latency Timer (MLT): Indicates the number of clocks the HBA is allowed to act 
as a master on PCI. 


2.1.8 Offset OEh: HTYPE — Header Type 


Bits Type | Reset | Description 

07 RO Impl | Multi-Function Device (MFD): Indicates whether the HBA is part of a multi-function 
Spec | device. 

06:00 RO 00h Header Layout (HL): Indicates that the HBA uses a target device layout. 


2.1.9 Offset OFh: BIST — Built In Self Test (Optional) 


The following register is optional, but if implemented, must look as follows. 
Bits Type | Reset | Description 
07 RO 1 BIST Capable (BC): Indicates whether the HBA has a BIST function. This does not 
indicate SATA BIST capability — this is only for an HBA related BIST function. 
Stat BIST (SB): Software sets this bit to ‘1’ to invoke BIST. The HBA clears this bit to 
06 RW 0 in F 
0’ when BIST is complete. 

05:04 RO 00 Reserved 

: Completion Code (CC): Indicates the completion code status of BIST. A non-zero 
03:00 RO Oh ess . 

value indicates a failure. 


2.1.10 Offset 10h — 20h: BARS — Other Base Addresses (Optional) 


These registers allocate memory or I/O spaces for other BARs. An example application of these BARs is 
to implement the native IDE and bus master IDE ranges for an HBA that wishes to support legacy 
software. 


2.1.11 Offset 24h: ABAR — AHCI Base Address 


This register allocates space for the HBA memory registers defined in section 3. The ABAR must be 
allocated to contain enough space for the global AHCI registers, the port specific registers for each port, 
and any vendor specific space (if needed). It is permissible to have vendor specific space after the port 
specific registers for the last HBA port. 


Bit | Reset |Description: 
Base Address (BA): Base address of register memory space. This represents a 
memory space for support of 32 ports. For HBAs that support fewer than 32-ports, 
31:13 more bits are allowed to be RW, and therefore less memory space is consumed. For 
HBAs that have vendor specific space at the end of the port specific memory space, 


more bits are allowed to be RO such that more memory space is consumed. 


12:04 (ee) 
03 | 0 | Prefetchable (PF): Indicates that this range is not pre-fetchable 
02:01 | 00 | Type (TP): Indicates that this range can be mapped anywhere in 32-bit address space 
ee 


00 Resource Type Indicator (RTE): Indicates a request for register memory space. 


2.1.12 Offset 2Ch: SS - Sub System Identifiers 


Bits Type | Reset | Description 
31:16 | RO Sou Subsystem ID (SSID): Indicates the sub-system identifier. 
15:00 RO Se Subsystem Vendor ID (SSVID): Indicates the sub-system vendor identifier 


2.1.13 Offset 30h: EROM — Expansion ROM (Optional) 
Bit_| Type | Reset |Description 


31:00 RW he ROM Base Address (RBA): Indicates the base address of the HBA expansion ROM.. 
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2.1.14 Offset 34h: CAP — Capabilities Pointer 
| Reset | Description 


Capability Pointer (CP): Indicates the first capability pointer offset. It points to 
the PCI Power management capability offset. 


2.1.15 Offset 3Ch: INTR - Interrupt Information 
Bits Type | Reset | Description 


15:08 | RO | Impl 
Spec 


Interrupt Pin (IPIN): This indicates the interrupt pin the HBA uses. 


Interrupt Line (ILINE): Software written value to indicate which interrupt line (vector) 
the interrupt is connected to. No hardware action is taken on this register. 


Informative Note: If the HBA is a single function PCI device, then INTR.IPIN should be set to 01h to 
indicate the INTA# pin. 


2.1.16 Offset 3Eh: MGNT — Minimum Grant (Optional) 


Bits Type | Reset | Description 

: Imp! | Grant (GNT): Indicates the minimum grant time (in % microseconds) that the device 
07:00 RO : 
Spec_| wishes grant asserted. 


07:00 RW 00h 


2.1.17 Offset 3Fh: MLAT — Maximum Latency (Optional) 


Bits Type | Reset | Description 

' Impl Latency (LAT): Indicates the maximum latency (in % microseconds) that the device 
07:00 RO : 
Spec | can withstand. 


2.2 PCI Power Management Capabilities 
Start (hex) | End (hex) Symbol | Name 


PMCAP PMCAP+1 PID PCI Power Management Capability ID 
PMCAP+2_| PMCAP+3 PC PCI Power Management Capabilities 
PMCAP+4 | PMCAP+7 PMCS PCI Power Management Control and Status 


2.2.1 Offset PMCAP: PID - PCI Power Management Capability ID 
Bit_| Type | Reset |  CCC*iescription 


Next Capability (NEXT): Indicates the location of the next capability item in the 


15:08 RO list. This can be other capability pointers (such as Message Signaled Interrupts, 
PCI-X, or PCI-Express) or it can be the last item in the list. 


07:00 | RO Cap ID (CID): Indicates that this pointer is a PCI power management. 
2.2.2 Offset PMCAP + 2h: PC — PCI Power Management Capabilities 


Bit Type | Reset Description 
PME_Support (PSUP): Indicates the states that can generate PME#. The encoding of 
this field is as follows: 


Bit State 
15 When set to ‘1’, PME# can be generated from D3coip. When cleared 

to ‘0’, PME# cannot be generated from D3coip. This bit may be a ‘1’ 

or ‘0’ for AHCI HBAs. 

14 When set to ‘1’, PME# can be generated from D3yor. When cleared 

15:11 RO to ‘0’", PME# cannot be generated from D3yor. This bit must be ‘1’ for 

AHCI HBAs. 

13 This bit must be ‘0’ for AHCI HBAs. D2 is not a supported HBA state. 

The behavior is undefined if the HBA is placed in this state. 

12 This bit must be ‘0’ for AHCI HBAs. D1 is not a supported HBA state. 

The behavior is undefined if the HBA is placed in this state. 

11 This bit must be ‘0’ for AHCI HBAs. PME# from DO is not supported 

— interrupts are used in DO. 
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10 
09 


08:06 


05 


04 
03 


02:00 


2.2.3 
Bit 


15 


14:09 


08 


07:02 


01:00 


RO 
RO 


RO 


RO 


RO 
RO 


RO 


D2_Support (D2S): The D2 state is not supported for AHCI HBAs 
D1_Support (D1S): The D1 state is not supported for AHCI HBAs 


Impl | Aux_Current (AUXC): Reports the maximum Suspend well current required when in 
Spec | the D3coip state. Refer to the PCI specification for definition of values. 


Impl | Device Specific Initialization (DSI): Indicates whether device-specific initialization is 
Spec | required. 
| 0 | PME Clock (PMEC): Indicates that PCI clock is not required to generate PME#. | 


Imp! | Version (VS): Indicates support for Revision 1.1 or higher revisions of the PC/ Power 


Offset PMCAP + 4h: PMCS — PCI Power Management Control And Status 


RO 


R/W 


PME Status (PMES): Set to ‘1’ by hardware when the HBA generates PME#. 


If the HBA supports waking from D3co.p, this bit is indeterminate at system boot. If the 
HBA does not support waking from D3coup, this bit is ‘0’ at system boot. 


PME Enable (PMEE): When set to ‘1’, the HBA asserts the PME# signal when PMES 
is set to ‘1’. 
If the HBA supports waking from D3co.p, this bit is indeterminate at system boot. If the 
HBA does not support waking from D3coup, this bit is ‘0’ at system boot. 

[| 0 | Reserved 
Power State (PS): This field is used both to determine the current power state of the 
HBA and to set a new power state. The values are: 


00 — DO state 
11- D3nHot state 


The D1 and D2 states are not supported for AHCI HBAs. When in the D3yor state, the 
HBA’s configuration space is available, but the register memory spaces are not. 
Additionally, interrupts are blocked. 


2.3. Message Signaled Interrupt Capability (Optional) 


Start (hex) End (hex) Symbol | Name 

MSICAP MSICAP+1 MID Message Signaled Interrupt Capability ID 
MSICAP+2 MSICAP+3 MC Message Signaled Interrupt Message Control 
MSICAP+4 MSICAP+7 MA Message Signaled Interrupt Message Address 


MSICAP+8 (MC.C64=0) | MSICAP+9 
MSICAP+C (MC.C64=1) | MSICAP.D 


MD Message Signaled Interrupt Message Data 


MSICAP+8 (MC.C64=1) | MSICAP+B MUA Message Signaled Interrupt Upper Address (Optional) 


2.3.1 Offset MSICAP: MID — Message Signaled Interrupt Identifiers 
Bits Type | Reset | Description 
15:08 RO Imp! | Next Pointer (NEXT): Indicates the next item in the list. This can be other capability 
, Spec | pointers (such as PCI-X or PCI-Express) or it can be the last item in the list. 
07:00 RO 05h_ | Capability ID (CID): Capabilities ID indicates MSI. 
2.3.2 Offset MSICAP + 2h: MC — Message Signaled Interrupt Message Control 
Bits Type | Reset | Description 
15:08 RO 0 Reserved 
07 RO Imp! | 64 Bit Address Capable (C64): Specifies whether capable of generating 64-bit 
Spec _| messages. 
Multiple Message Enable (MME): Indicates the number of messages the HBA should 
06:04 RW 000 | assert. See section 10.6.2.2. If the value programmed into this field exceeds the MMC 
field in this register, the results are indeterminate. 
03:01 RO Impl | Multiple Message Capable (MMC): Indicates the number of messages the HBA 
; Spec | wishes to assert. See section 10.6.2.2. 
00 RW 0 MSI Enable (MSIE): If set to ‘1’, MSI is enabled and the traditional interrupt pins are not 
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used to generate interrupts. If cleared to ‘0’, MSI operation is disabled and the 
traditional interrupt pins are used. 
2.3.3 Offset MSICAP + 4h: MA — Message Signaled Interrupt Message Address 
Bits Type | Reset | Description 
. Address (ADDR): Lower 32 bits of the system specified message address, always DW 
31:02 RW 0 aligned 
01:00 RO 00 Reserved 
2.3.4 Offset MSICAP + (8h or Ch): MD — Message Signaled Interrupt Message Data 
Bits Type | Reset | Description 
Data (Data): This 16-bit field is programmed by system software if MSI is enabled. Its 
15:00 RW 0 content is driven onto the lower word (PCI AD[15:0]) during the data phase of the MSI 
memory write transaction. 
2.3.5 Offset MSICAP + 8h: MUA — Message Signaled Interrupt Upper Address (Optional) 
Bits Type | Reset | Description 
31-00 RW 0 Upper Address (UADDR): Upper 32 bits of the system specified message 
: address. This register is optional and only implemented if MC.C64=1. 


2.4 Serial ATA Capability (Optional) 


This set of registers when supported is used for the Index-Data Pair mechanism described in section 


10.13. 
Start (hex) End (hex) Symbol | Name 
SATACAP _ | SATACAP+3 | SATACRO | Serial ATA Capability Register 0 
SATACAP+4 | SATACAP+7 | SATACR1 | Serial ATA Capability Register 1 
2.4.1. Offset SATACAP: SATACRO - Serial ATA Capability Register 0 
Bit_| Type | Reset | 0 Ceescription 
31:24 | RO 
; Major Revision (MAJREV): Major revision number of the SATA Capability 
23:20 RO th : : 
Pointer implemented. 
: Minor Revision (MINREV): Minor revision number of the SATA Capability Pointer 
19:16 RO Oh ; 
implemented. 
ici Next Capability (NEXT): Indicates the location of the next capability item in the 
15:08 RO S ie list. This can be other capability pointers (such as Message Signaled Interrupts, 
P PCI-X, or PCI-Express) or it can be the last item in the list. 
07:00 | RO Cap ID (CID): Indicates that this pointer is a SATA Capability. 
2.4.2 Offset SATACAP + 4h: SATACR1 -— Serial ATA Capability Register 1 
Bit_| Type | Reset]  Cescription 
31:16 | RO_| 0 | Reserved 
BAR Offset (BAROFST): Indicates the offset into the BAR where the Index-Data Pair 
are located in Dword granularity. Possible values include: 
000h = Oh offset 
. 001h = 4h offset 
a RQ 002h = 8h offset 
003h = Ch offset 
004h = 10h offset 
FFFFh = 3FFFFh offset (maximum) 
BAR Location (BARLOC): Indicates the absolute PCI Configuration Register address 
3:0 RO of the BAR containing the Index-Data Pair in Dword granularity. Possible values are: 
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0100b = 10h (BARO) 
0101b = 14h (BAR1) 
0110b = 18h (BAR2) 
0111b = 1Ch (BAR3) 
1000b = 20h (BAR4 


) 
1001b = 24h (BARS) 
1111b = Index-Data Pair is implemented in Dwords directly following SATACR‘1 in the 
PCI configuration space. 


All other values are reserved. 


2.5 Other Capability Pointers 


Though not mentioned in this specification, other capability pointers may be necessary, depending upon 
the implementation space. Examples would be the PCI-X capability for PCI-X implementations, PCI- 
Express capability for PCI-Express implementations, and potentially the vendor specific capability pointer. 


These capabilities are beyond the scope of this specification. 
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3 HBA Memory Registers 


The memory mapped registers within the HBA exist in non-cacheable memory space. Additionally, 
locked accesses are not supported. If software attempts to perform locked transactions to the registers, 
indeterminate results may occur. Register accesses shall have a maximum size of 64-bits; 64-bit access 
must not cross an 8-byte alignment boundary. 


The registers are broken into two sections — global registers and port control. All registers that start 
below address 100h are global and meant to apply to the entire HBA. The port control registers are the 
same for all ports, and there are as many register banks as there are ports. 


All registers not defined and all reserved bits within registers return ‘0’ when read. 


Start End_ | Description 

00h 23h Generic Host Control 

24h 9Fh Reserved 

AOh FFh Vendor Specific registers 

100h 17Fh | Port 0 port control registers 

180h 1FFh | Port 1 port control registers 

200h FFFh_ | (Ports 2 — port 29 control registers) 
1000h | 107Fh | Port 30 port control registers 
1080h | 10FFh | Port 31 port control registers 


3.1 Generic Host Control 


The following registers apply to the entire HBA. 


Start End Symbol Description 

00h 03h CAP Host Capabilities 

04h 07h GHC Global Host Control 

08h OBh IS Interrupt Status 

OCh OFh Pl Ports Implemented 

10h 13h VS Version 

14h 17h CCC_CTL Command Completion Coalescing Control 
18h 1Bh CCC_PORTS_ | Command Completion Coalsecing Ports 
1Ch 1Fh EM_LOC Enclosure Management Location 

20h 23h EM CTL Enclosure Management Control 


3.1.1. Offset 00h: CAP — HBA Capabilities 


This register indicates basic capabilities of the HBA to driver software. 


Bit WResets||Descnphone x a eGts eee. tee Le ey 
Supports 64-bit Addressing (S64A): Indicates whether the HBA can access 64-bit 
31 Impl | data structures. When set to ‘1’, the HBA shall make the 32-bit upper bits of the port 
Spec | DMA Descriptor, the PRD Base, and each PRD entry read/write. When cleared to ‘0’, 
these are read-only and treated as ‘0’ by the HBA. 
Supports Native Command Queuing (SNCQ): Indicates whether the HBA supports 
Impl Serial ATA native command queuing. If set to ‘1’, an HBA shall handle DMA Setup 
30 Spec FlSes natively, and shall handle the auto-activate optimization through that FIS. If 
cleared to ‘0’, native command queuing is not supported and software should not issue 
any native command queuing commands. 
Supports SNotification Register (SSNTF): When set to ‘1’, the 
29 Impl | HBA supports the PxSNTF (SNotification) register and its associated functionality. 
Spec | When cleared to ‘0’, the HBA does not support the PxSNTF (SNotification) register and 
its associated functionality. Refer to section 10.10.1. 
Supports Mechanical Presence Switch (SMPS): When set to ‘1’, the HBA supports 
28 Eivaintt mechanical presence switches on its ports for use in hot plug operations. When 
cleared to ‘0’, this function is not supported. This value is loaded by the BIOS prior to 
OS initialization. 
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Bit 


27 


26 


25 


24 


23:20 


19 


18 


17 


16 


15 


14 


13 


| Reset |Description 


Hwinit 


Impl. 
Spec 


Supports Staggered Spin-up (SSS): When set to ‘1’, the HBA supports staggered 
spin-up on its ports, for use in balancing power spikes. When cleared to ‘0’, this 
function is not supported. This value is loaded by the BIOS prior to OS initiallization. 
Supports Aggressive Link Power Management (SALP): When set to ‘1’, the HBA 
can support auto-generating link requests to the Partial or Slumber states when there 
are no commands to process. When cleared to ‘0’, this function is not supported and 
software shall treat the PxCMD.ALPE and PxCMD.ASP bits as reserved. Refer to 
section 8.3.1.3. 

Supports Activity LED (SAL): When set to ‘1’, the HBA supports a single activity 
indication output pin. This pin can be connected to an LED on the platform to indicate 
device activity on any drive. When cleared to ‘0’, this function is not supported. See 
section 10.10 for more information. 

Supports Command List Override (SCLO): When set to ‘1’, the HBA supports the 
PxCMD.CLO bit and its associated function. When cleared to ‘0’, the HBA is not 
capable of clearing the BSY and DRQ bits in the Status register in order to issue a 
software reset if these bits are still set from a previous operation. 

Interface Speed Support (ISS): Indicates the maximum speed the HBA can support 
on its ports. These encodings match the system software programmable 
PxSCTL.DET.SPD field. Values are: 


Bits Definition 

0000 Reserved 

0001 Gen 1 (1.5 Gbps) 

0010 Gen 1 (1.5 Gbps) and Gen 2 (3 
Gbps) 

0011-1111 Reserved 


Supports Non-Zero DMA Offsets (SNZO): When set to ‘1’, indicates that the HBA 


can support non-zero DMA offsets for DMA Setup FlSes. This bit is reserved for future 
AHCI enhancements. AHCI 1.0 and 1.1 HBAs shall have this bit cleared to ‘0’. 


Supports AHCI mode only (SAM): The SATA controller may optionally support AHCI 
access mechanisms only. A value of '0' indicates that in addition to the native AHCI 
mechanism (via ABAR), the SATA controller implements a legacy, task-file based 
register interface such as SFF-8038i. A value of '1' indicates that the SATA controller 
does not implement a legacy, task-file based register interface. 

Supports Port Multiplier (SPM): Indicates whether the HBA can support a Port 
Multiplier. When set, a Port Multiplier using command-based switching is supported. 
When cleared to ‘0’, a Port Multiplier is not supported, and a Port Multiplier may not be 
attached to this HBA. 

FIS-based Switching Supported (FBSS): When set to ‘1’, indicates that the HBA 
supports Port Multiplier FlS-based switching. When cleared to ‘0’, indicates that the 
HBA does not support FIS-based switching. AHCI 1.0 and 1.1 HBAs shall have this bit 
cleared to ‘0’. 

PIO Multiple DRQ Block (PMD): If set to ‘1’, the HBA supports multiple DRQ block 
data transfers for the PIO command protocol. If cleared to ‘0’ the HBA only supports 
single DRQ block data transfers for the PIO command protocol. 

Slumber State Capable (SSC): Indicates whether the HBA can support transitions to 
the Slumber state. When cleared to ‘0’, software must not allow the HBA to initiate 
transitions to the Slumber state via agressive link power management nor the 
PxCMD.ICC field in each port, and the PxSCTL.IPM field in each port must be 
programmed to disallow device initiated Slumber requests. When set to ‘1’, HBA and 
device initiated Slumber requests can be supported. 

Partial State Capable (PSC): Indicates whether the HBA can support transitions to the 
Partial state. When cleared to ‘0’, software must not allow the HBA to initiate transitions 
to the Partial state via agressive link power management nor the PxCMD.ICC field in 
each port, and the PxSCTL.IPM field in each port must be programmed to disallow 
device initiated Partial requests. When set to ‘1’, HBA and device initiated Partial 
requests can be supported. 
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12:08 


07 


06 


05 


04:00 


Bit | Reset |Description 


Number of Command Slots (NCS): 0’s based value indicating the number of 
command slots per port supported by this HBA. A minimum of 1 and maximum of 32 
slots per port can be supported. The same number of command slots is available on 
each implemented port. 

Command Completion Coalescing Supported (CCCS): When set to ‘1’, indicates 
that the HBA supports command completion coalescing as defined in section 11. When 
command completion coalescing is supported, the HBA has implemented the 
CCC_CTL and the CCC_PORTS global HBA registers. When cleared to ‘0’, indicates 
that the HBA does not support command completion coalescing and the CCC_CTL and 
CCC_PORTS global HBA registers are not implemented. 

Enclosure Management Supported (EMS): When set to ‘1’, indicates that the HBA 
supports enclosure management as defined in section 12. When enclosure 
management is supported, the HBA has implemented the EM_LOC and EM_CTL 
global HBA registers. When cleared to ‘0’, indicates that the HBA does not support 
enclosure management and the EM_LOC and EM_CTL global HBA registers are not 
implemented. 

Supports External SATA (SXS): When set to ‘1’, indicates that the HBA has one or 
more Serial ATA ports that has a signal only connector that is externally accessible. If 
this bit is set to ‘1’, software may refer to the PxCMD.ESP bit to determine whether a 
specific port has its signal connector externally accessible as a signal only connector 
(i.e. power is not part of that connector). When the bit is cleared to ‘0’, indicates that 
the HBA has no Serial ATA ports that have a signal only connector externally 
accessible. 

Number of Ports (NP): 0’s based value indicating the maximum number of ports 
supported by the HBA silicon. A maximum of 32 ports can be supported. A value of 
‘Oh’, indicating one port, is the minimum requirement. Note that the number of ports 
indicated in this field may be more than the number of ports indicated in the GHC.PI 
register. 


3.1.2 Offset 04h: GHC — Global HBA Control 


This register controls various global actions of the HBA. 


| Bit_| Type | Reset | Description 


AHCI Enable (AE): When set, indicates that communication to the HBA shall be via 
AHCI mechanisms. This can be used by an HBA that supports both legacy 
mechanisms (such as SFF-8038i) and AHCI to know when the HBA is running under an 
AHCI driver. 


When set, software shall only communicate with the HBA using AHCI. When cleared, 
software shall only communicate with the HBA using legacy mechanisms. When 
cleared FlSes are not posted to memory and no commands are sent via AHCI 
mechanisms. 


Software shall set this bit to ‘1’ before accessing other AHCI registers. 


The implementation of this bit is dependent upon the value of the CAP.SAM bit. If 
CAP.SAM is '0', then GHC.AE shall be read-write and shall have a reset value of '0'. If 
CAP.SAM is '1', then AE shall be read-only and shall have a reset value of '1'. 


| 30:03 | RO | 0 | Reserved 
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MSI Revert to Single Message (MRSM): When set to ‘1’ by hardware, indicates that 
the HBA requested more than one MSI vector but has reverted to using the first vector 
only. When this bit is cleared to ‘0’, the HBA has not reverted to single MSI mode (i.e. 
hardware is already in single MSI mode, software has allocated the number of 
messages requested, or hardware is sharing interrupt vectors if MC.MME <MC.MMC). 


The HBA may revert to single MSI mode when the number of vectors allocated by the 
host is less than the number requested. This bit shall only be set to ‘1’ when the 
following conditions hold: 

e MC.MSIE = ‘1’ (MSI is enabled) 

e MC.MMC > 0 (multiple messages requested) 

e MC.MME > 0 (more than one message allocated) 

e MC.MME != MC.MMC (messages allocated not equal to number requested) 


When this bit is set to ‘1’, single MSI mode operation is in use and software is 
responsible for clearing bits in the IS register to clear interrupts. 


This bit shall be cleared to ‘0’ by hardware when any of the four conditions stated is 
false. This bit is also cleared to ‘0’ when MC.MSIE = ‘1’ and MC.MME = Oh. In this 
case, the hardware has been programmed to use single MSI mode, and is not 
“reverting” to that mode. 

Interrupt Enable (IE): This global bit enables interrupts from the HBA. When cleared 
01 RW 0 (reset default), all interrupt sources from all ports are disabled. When set, interrupts are 
enabled. 


HBA Reset (HR): When set by SW, this bit causes an internal reset of the HBA. All 
state machines that relate to data transfers and queuing shall return to an idle 
condition, and all ports shall be re-initialized via COMRESET (if staggered spin-up is 
not supported). If staggered spin-up is supported, then it is the responsibility of 
00 RW1 0 software to spin-up each port after the reset has completed. 


When the HBA has performed the reset action, it shall reset this bit to ‘0’. A software 
write of ‘0’ shall have no effect. For a description on which bits are reset when this bit is 
set, see section 10.4.3. 


3.1.3 Offset 08h: IS — Interrupt Status Register 


This register indicates which of the ports within the controller have an interrupt pending and require 
service. 


| Bit | Type | Reset | Description 
Interrupt Pending Status (IPS): If set, indicates that the corresponding port has an 
interrupt pending. Software can use this information to determine which ports require 
31:0 RWC service after an interrupt. 


The IPS[x] bit is only defined for ports that are implemented or for the command 
completion coalescing interrupt defined by CCC_CTL.INT. All other bits are reserved. 


3.1.4 Offset OCh: PI - Ports Implemented 


This register indicates which ports are exposed by the HBA. It is loaded by the BIOS. It indicates which 
ports that the HBA supports are available for software to use. For example, on an HBA that supports 6 
ports as indicated in CAP.NP, only ports 1 and 3 could be available, with ports 0, 2, 4, and 5 being 
unavailable. 


Software must not read or write to registers within unavailable ports. 


The intent of this register is to allow system vendors to build platforms that support less than the full 
number of ports implemented on the HBA silicon. 


Type | Reset | Description 
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Port Implemented (PI): This register is bit significant. If a bit is set to ‘1’, the 
corresponding port is available for software to use. If a bit is cleared to ‘0’, the port is 
31:0 RO Hwinit | not available for software to use. The maximum number of bits set to ‘1’ shall not 


exceed CAP.NP + 1, although the number of bits set in this register may be fewer than 
CAP.NP +1. Atleast one bit shall be set to ‘1’. 


3.1.5 Offset 10h: VS — AHCI Version 


This register indicates the major and minor version of the AHCI specification that the HBA implementation 
supports. The upper two bytes represent the major version number, and the lower two bytes represent 
the minor version number. Example: Version 3.12 would be represented as 00030102h. Three versions 
of the specification are valid: 0.95, 1.0, and 1.1. 


3.1.5.1. VS Value for 0.95 Compliant HBAs 


| Reset |Description 
RO 0000h | Major Version Number (MJR): Indicates the major version is “0” 


RO 0905h | Minor Version Number (MNR): Indicates the minor version is “95”. 
3.1.5.2 VS Value for 1.0 Compliant HBAs 


Bit_ | Type | Reset |Description 
31:16 RO 0001h | Major Version Number (MJR): Indicates the major version is “1” 


15:00 RO 0000h | Minor Version Number (MNR): Indicates the minor version is “0”. 
3.1.5.3. VS Value for 1.1 Compliant HBAs 


Bit_ | Type | Reset |Description 
31:16 RO 0001h | Major Version Number (MJR): Indicates the major version is “1” 


15:00 RO 0100h | Minor Version Number (MNR): Indicates the minor version is “10”. 
3.1.6 Offset 14h: CCC_CTL —-Command Completion Coalescing Control 


The command completion coalescing control register is used to configure the command completion 
coalescing feature for the entire HBA. 


Implementation Note: HBA state variables (examples include hCccComplete and hCccTimer) are used 
to describe the required externally visible behavior. Implementations are not required to have internal 
state values that directly correspond to these variables. 


| Bit | Type | Reset |Description 
Timeout Value (TV): The timeout value is specified in 1 millisecond intervals. The timer 
accuracy shall be within 5%. hCccTimer is loaded with this timeout value. hCccTimer is 
only decremented when commands are outstanding on selected ports, as defined in 
section 11.2. The HBA will signal a CCC interrupt when hCccTimer has decremented to 
‘0’. hCccTimer is reset to the timeout value on the assertion of each CCC interrupt. A 
timeout value of ‘0’ is reserved. 
Command Completions (CC): Specifies the number of command completions that are 
necessary to cause a CCC interrupt. The HBA has an internal command completion 
counter, hCccComplete. hCccComplete is incremented by one each time a selected 
port has a command completion. When hCccComplete is equal to the command 
completions value, a CCC interrupt is signaled. The internal command completion 
counter is reset to ‘0’ on the assertion of each CCC interrupt. A value of ‘0’ for this field 
shall disable CCC interrupts being generated based on the number of commands 
completed, i.e. CCC interrupts are only generated based on the timer in this case. 
Interrupt (INT): Specifies the interrupt used by the CCC feature. This interrupt must be 
marked as unused in the Ports Implemented (PI) register by the corresponding bit being 
set to ‘0’. Thus, the CCC interrupt corresponds to the interrupt for an unimplemented 
port on the controller. When a CCC interrupt occurs, the IS.IPS[INT] bit shall be 
asserted to ‘1’. This field also specifies the interrupt vector used for MSI. 


| 27 | RO | 0h | Reseved 
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Enable (EN): When cleared to ‘0’, the command completion coalescing feature is 
disabled and no CCC interrupts are generated. When set to ‘1’, the command 


completion coalescing feature is enabled and CCC interrupts may be generated based 
on timeout or command completion conditions. Software shall only change the contents 
of the TV and CC fields when EN is cleared to ‘0’. On transition of this bit from ‘0’ to ‘1’, 
any updated values for the TV and CC fields shall take effect. 


3.1.7. Offset 18h: CCC_PORTS — Command Completion Coalescing Ports 


The command completion coalescing ports register is used to specify the ports that are coalesced as part 
of the CCC feature when CCC_CTL.EN = ‘1’. 


Bit EReset:|(Descriptcna sul na eae ete en oe ee 
Ports (PRT): This register is bit significant. Each bit corresponds to a particular port, 
where bit 0 corresponds to port 0. If a bit is set to ‘1’, the corresponding port is part of 
: the command completion coalescing feature. If a bit is cleared to ‘0’, the port is not part 
31:0 ‘ : : pee aes : 
of the command completion coalescing feature. Bits set to ‘1’ in this register must also 
have the corresponding bit set to ‘1’ in the Ports Implemented register. An updated 
value for this field shall take effect within one timer increment (1 millisecond). 


3.1.8 Offset 1Ch: EM_LOC — Enclosure Management Location 


The enclosure management location register identifies the location and size of the enclosure 
management message buffer. 


ces Description 


Imp! | Offset (OFST): The offset of the message buffer in Dwords from the beginning of the 
31:16 16 
Spec _| ABAR. 


Buffer Size (SZ): Specifies the size of the transmit message buffer area in Dwords. 
Impl both transmit and receive buffers are supported, then the transmit buffer begins is 
Spec ABAR[EM_LOC.OFST*4] and the receive buffer directly follows it. If both transmit and 

receive buffers are supported, both buffers are of the size indicated in the Buffer Size 


field. A value of ‘0’ is invalid. 


3.1.9 Offset 20h: EM_CTL — Enclosure Management Control 


This register is used to control and obtain status for the enclosure management interface. The register 
includes information on the attributes of the implementation, enclosure management messages 
supported, the status of the interface, whether any messages are pending, and is used to initiate sending 
messages. 


Bit_| Type | Reset |Description 
BU2E lew! 1) 00-5 ReseMeds ee ee 
Port Multiplier Support (ATTR.PM): If set to ‘1’, the HBA supports enclosure 
management messages for devices attached via a Port Multiplier. If cleared to ‘0’, the 
HBA does not support enclosure management messages for devices attached via a 
27 RO Port Multiplier. When cleared to ‘0’, software should use the Serial ATA enclosure 
management bridge that is built into many Port Multipliers for enclosure services with 
these devices. For more information on Serial ATA enclosure management bridges, 
refer to the Serial ATA II: Extensions to Serial ATA 1.0a revision 1.2 specification. 
Activity LED Hardware Driven (ATTR.ALHD): If set to ‘1’, the HBA drives the activity 
26 RO LED for the LED message type in hardware and does not utilize software settings for 
this LED. The HBA does not begin transmitting the hardware based activity signal until 


after software has written CTL.TM=1 after a reset condition. 


Transmit Only (ATTR.XMT): If set to ‘1’, the HBA only supports transmitting 
25 RO messages and does not support receiving messages. If cleared to ‘0’, the HBA 
supports transmitting and receiving messages. 

Single Message Buffer (ATTR.SMB): If set to ‘1’, the HBA has one message buffer 
that is shared for messages to transmit and messages received. In this case, 
24 RO unsolicited receive messages are not supported and it is software’s responsibility to 
manage access to this buffer. If cleared to ‘0’, there are separate receive and transmit 
buffers such that unsolicited messages could be supported. 


23:20 | RO | 0 |Reseved 
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Bit_| Type | Reset |Description 
Imp! | SGPIO Enclosure Management Messages (SUPP.SGPIO): If set to ‘1’, the HBA 
19 RO : ; 
Spec | supports the SGPIO register interface message type. 
Imp! | SES-2 Enclosure Management Messages (SUPP.SES2): If set to ‘1’, the HBA 
18 RO 
Spec | supports the SES-2 message type. 
Imp! | SAF-TE Enclosure Management Messages (SUPP.SAFTE): If set to ‘1’, the HBA 
17 RO 
Spec | supports the SAF-TE message type. 
Impl | LED Message Types (SUPP.LED): If set to ‘1’, the HBA supports the LED message 
16 RO : f 
Spec_ | type defined in section 12.2.1. 
Reset (CTL.RST): When set to ‘1’ by software, the HBA shall reset all enclosure 
management message logic and the attached enclosure processor (if applicable) and 
take all appropriate reset actions to ensure messages can be transmitted/received after 
the reset. After the HBA completes the reset operation, the HBA shall set the value to 
‘0’. A write of ‘0’ by software to this field shall have no effect. 


a 
Transmit Message (CTL.TM): When set to ‘1’ by software, the HBA shall transmit the 
message contained in the message buffer. When the message is completely sent, the 
a 


15:10 RO 


09 RW1 


08 RW1 HBA shall clear this bit to ‘0’. A write of ‘0’ to this bit by software shall have no effect. 

Software shall not change the contents of the message buffer while CTL.TM is set to 
‘1. 
Message Received (STS.MR): The HBA sets this bit to a ‘1’ when a message is 
completely received into the message buffer. When software detects this bit is a ‘1’, 
software should read the message and perform any actions necessary. When software 
is finished reading the message in the buffer, software writes a ‘1’ to this bit in order to 
clear it. A write of ‘0’ to this bit by software shall have no effect. 


07:01 RO 


00 RWC 


3.2. Vendor Specific Registers 
Registers at offset AOh to FFh are vendor specific. 
3.3. Port Registers (one set per port) 


The following registers describe the registers necessary to implement port 0. Additional ports shall have 
the same register mapping. Port 1 starts at 180h, port 2 starts at 200h, port 3 at 280h, etc. The algorithm 
for software to determine the offset is as follows: 

e Port offset = 100h + (PI Asserted Bit Position * 80h) 


Start End Symbol Description 
100h 103h POCLB Port 0 Command List Base Address 
104h 107h POCLBU Port 0 Command List Base Address Upper 32-Bits 
108h 10Bh POFB Port 0 FIS Base Address 
10Ch 10Fh POFBU Port 0 FIS Base Address Upper 32-Bits 
110h 113h POIS Port 0 Interrupt Status 
114h 117h POIE Port 0 Interrupt Enable 
118h 11Bh POCMD Port 0 Command and Status 
11Ch 11Fh Reserved Reserved 
120h 123h POTFD Port 0 Task File Data 
124h 127h POSIG Port 0 Signature 
128h 12Bh POSSTS Port 0 Serial ATA Status (SCRO: SStatus) 
12Ch | 12Fh POSCTL Port 0 Serial ATA Control (SCR2: SControl) 
130h 133h POSERR Port 0 Serial ATA Error (SCR1: SError) 
134h 137h POSACT Port 0 Serial ATA Active (SCR3: SActive) 
138h 13Bh POCI Port 0 Command Issue 
13Ch | 13Fh POSNTF Port 0 SNotification 
140h 143h Reserved Reserved for FIS-based Switching Definition 
144h 16Fh Reserved Reserved 
170h 17Fh POVS Port 0 Vendor Specific 

3.3.1. Offset 100h: POCLB — Port 0 Command List Base Address 

Bit_| Type | Reset |Description 


20 


Serial ATA AHCI 1.1 Specification Revision 1_1.doc 


Command List Base Address (CLB): Indicates the 32-bit base physical address for 
the command list for this port. This base is used when fetching commands to execute. 


oe avy The structure pointed to by this address range is 1K-bytes in length. This address must 
be 1K-byte aligned as indicated by bits 09:00 being read only. 
00 [RO [0 [Reseved CS 
3.3.2 Offset 104h: POCLBU — Port 0 Command List Base Address Upper 32-bits 
Bit_| Type | Reset | Description 
Command List Base Address Upper (CLBU): Indicates the upper 32-bits for the 
RW/ command list base physical address for this port. This base is used when fetching 
31:00 | Ro commands to execute. 
This register shall be read only ‘0’ for HBAs that do not support 64-bit addressing. 
3.3.3 Offset 108h: POFB — Port 0 FIS Base Address 
Bit_| Type | Reset |Description 
FIS Base Address (FB): Indicates the 32-bit base physical address for received 
31:08 RW FlSes. The structure pointed to by this address range is 256 bytes in length. This 
address must be 256-byte aligned as indicated by bits 07:00 being read only. 
or00|RO[ 0 [Resoved 
3.3.4 Offset 10Ch: POFBU — Port 0 FIS Base Address Upper 32-bits 
Bit_| Type | Reset |Description 
FIS Base Address Upper (FBU): Indicates the upper 32-bits for the received FIS base 
31:00 oa physical address for this port. 
This register shall be read only ‘0’ for HBAs that do not support 64-bit addressing. 
3.3.5 Offset 110h: POIS — Port 0 Interrupt Status 
Bit Type | Reset | Description 
Cold Port Detect Status (CPDS): When set, a device status has changed as detected 
31 RWC by the cold presence detect logic. This bit can either be set due to a non-connected 
port receiving a device, or a connected port having its device removed. This bit is only 
valid if the port supports cold presence detect as indicated by PXCMD.CPD set to ‘1’. 
30 RWC Task File Error Status (TFES): This bit is set whenever the status register is updated 
by the device and the error bit (bit 0) is set. 
Host Bus Fatal Error Status (HBFS): Indicates that the HBA encountered a host bus 
29 RWC error that it cannot recover from, such as a bad software pointer. In PCI, such an 
indication would be a target or master abort. 
28 RWC Host Bus Data Error Status (HBDS): Indicates that the HBA encountered a data error 
(uncorrectable ECC / parity) when reading from or writing to system memory. 
27 RWC Interface Fatal Error Status (IFS): Indicates that the HBA encountered an error on 
the Serial ATA interface which caused the transfer to stop. Refer to section 6.1.2. 
26 RWC Interface Non-fatal Error Status (INFS): Indicates that the HBA encountered an error 
on the Serial ATA interface but was able to continue operation. Refer to section 6.1.2. 
25 | RO 
24 RWC Overflow Status (OFS): Indicates that the HBA received more bytes from a device 
than was specified in the PRD table for the command. 
Incorrect Port Multiplier Status (IPMS): Indicates that the HBA received a FIS from a 
device whose Port Multiplier field did not match what was expected. The IPMS bit may 
23 RWC be set during enumeration of devices on a Port Multiplier due to the normal Port 
Multiplier enumeration process. It is recommended that IPMS only be used after 
enumeration is complete on the Port Multiplier. 
PhyRdy Change Status (PRCS): When set to ‘1’ indicates the internal PhyRdy signal 
22 RO changed state. This bit reflects the state of POSERR.DIAG.N. To clear this bit, 
software must clear POSERR.DIAG.N to ‘0’. 
21:08 |__RO 
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Bit_| Type | Reset | Description 
Device Mechanical Presence Status (DMPS): When set, indicates that a mechanical 
presence switch attached to this port has been opened or closed, which may lead to a 
change in the connection state of the device. This bit is only valid if both CAP.SMPS 
and POCMD.MPSP are set to ‘1’. 

Port Connect Change Status (PCS): 1=Change in Current Connect Status. O=No 
06 RO change in Current Connect Status. This bit reflects the state of PXSERR.DIAG.X. This 
bit is only cleared when PxSERR.DIAG.X is cleared. 


Descriptor Processed (DPS): A PRD with the ‘I’ bit set has transferred all of its data. 
05 RWC ; 
Refer to section 5.4.2. 


Unknown FIS Interrupt (UFS): When set to ‘1’, indicates that an unknown FIS was 
received and has been copied into system memory. This bit is cleared to ‘0’ by 
software clearing the PxSERR.DIAG.F bit to ‘0’. Note that this bit does not directly 
04 RO reflect the PxXSERR.DIAG.F bit. PxSERR.DIAG.F is set immediately when an unknown 
FIS is detected, whereas this bit is set when that FIS is posted to memory. Software 
should wait to act on an unknown FIS until this bit is set to ‘1’ or the two bits may 
become out of sync. 

Set Device Bits Interrupt (SDBS): A Set Device Bits FIS has been received with the 
03 RWC aia mate 

I’ bit set and has been copied into system memory. 


DMA Setup FIS Interrupt (DSS): A DMA Setup FIS has been received with the ‘I’ bit 
02 RWC ane 

set and has been copied into system memory. 
PIO Setup FIS Interrupt (PSS): A PIO Setup FIS has been received with the ‘Il’ bit set, 
01 RWC it has been copied into system memory, and the data related to that FIS has been 
transferred. This bit shall be set even if the data transfer resulted in an error. 


Device to Host Register FIS Interrupt (DHRS): A D2H Register FIS has been 
received with the ‘I’ bit set, and has been copied into system memory. 


3.3.6 Offset 114h: POIE — Port 0 Interrupt Enable 


This register enables and disables the reporting of the corresponding interrupt to system software. When 
a bit is set (‘1’) and the corresponding interrupt condition is active, then an interrupt is generated. Interrupt 
sources that are disabled (‘0’) are still reflected in the status registers. This register is symmetrical with 
the POIS register. 


07 RWC 


00 RWC 


Bit_| Type | Reset |Description CC 
Cold Presence Detect Enable (CPDE): When set, GHC.IE is set, and POS.CPDS is 
31 se set, the HBA shall generate an interrupt. 
For systems that do not support cold presence detect, this bit shall be a read-only ‘0’. 
30 RW Task File Error Enable (TFEE): When set, GHC.IE is set, and POS.TFES is set, the 
HBA shall generate an interrupt. 
29 RW Host Bus Fatal Error Enable (HBFE): When set, GHC.IE is set, and POIS.HBFS is 
set, the HBA shall generate an interrupt. 
Host Bus Data Error Enable (HBDE): when set, GHC.IE is set, and POIS.HBDS is 
28 RW : 
set, the HBA shall generate an interrupt.. 
27 RW Interface Fatal Error Enable (IFE): When set, GHC.IE is set, and POIS.IFS is set, the 
HBA shall generate an interrupt.. 
Interface Non-fatal Error Enable (INFE): When set, GHC.IE is set, and POIS.INFS is 
26 RW : 
set, the HBA shall generate an interrupt. 
201 ARO 20" | ReSenedh 8 ie se S| 
24 RW Overflow Enable (OFE): When set, and GHC.IE and POIS.OFS are set, the HBA shall 
generate an interupt. 
Incorrect Port Multiplier Enable (IPME): When set, and GHC.IE and POIS.IPMS are 
23 RW ; 
set, the HBA shall generate an interupt. 
22 RW PhyRdy Change Interrupt Enable (PRCE): When set to ‘1’, and GHC.IE is set to ‘1’, 
and POIS.PRCS is set to ‘1’, the HBA shall generate an interrupt. 
21:08 | RO | 0 | Reserved 
Device Mechanical Presence Enable (DMPE): When set, and GHC.IE is set to ‘1’, 
i: RW/ and POIS.DMPS is set, the HBA shall generate an interrupt. 
RO For systems that do not support a mechanical presence switch, this bit shall be a read- 
only ‘0’. 
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Port Change Interrupt Enable (PCE): When set, GHC.IE is set, and POIS.PCS is set, 
the HBA shall generate an interrupt. 


Fae Descriptor Processed Interrupt Enable (DPE): When set, GHC.IE is set, an 

POIS.DPS is set, the HBA shall generate an interrupt. 

ee] Unknown FIS Interrupt Enable (UFE): When set, GHC.IE is set, and POIS.UFS is set 
to ‘1’, the HBA shall generate an interrupt. 

ae Set Device Bits FIS Interrupt Enable (SDBE): When set, GHC.IE is set, and 
POIS.SDBS is set, the HBA shall generate an interrupt. 

Es DMA Setup FIS Interrupt Enable (DSE): When set, GHC.IE is set, and POIS.DSS is 
set, the HBA shall generate an interrupt. 

Ea PIO Setup FIS Interrupt Enable (PSE): When set, GHC.IE is set, and POIS.PSS is 
set, the HBA shall generate an interrupt. 

ae Device to Host Register FIS Interrupt Enable (DHRE): When set, GHC.IE is set, 
and POIS.DHRS is set, the HBA shall generate an interrupt. 
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3.3.7 Offset 118h: POCMD — Port 0 Command and Status 
Bit | Reset |Description  ——“‘CS;S™CSCS™C™CCCOCOCSCSCSC‘“(‘(‘NNC‘ésN 


Interface Communication Control (ICC): This field is used to control power 
management states of the interface. If the Link layer is currently in the L_IDLE state, 
writes to this field shall cause the HBA to initiate a transition to the interface power 
management state requested. If the Link layer is not currently in the L_IDLE state, 
writes to this field shall have no effect. 


Value Definition 
Fh - 7h Reserved 
6h Slumber: This shall cause the HBA to request a transition of the 
interface to the Slumber state. The SATA device may reject the 
request and the interface shall remain in its current state. 
Reserved 
Partial: This shall cause the HBA to request a transition of the 
interface to the Partial state. The SATA device may reject the 
31:28 request and the interface shall remain in its current state. 
Active: This shall cause the HBA to request a transition of the 
interface into the active state. 
No-Op / Idle: When software reads this value, it indicates the HBA is 
ready to accept a new interface control command, although the 
transition to the previously selected state may not yet have occurred. 


When system software writes a non-reserved value other than No-Op (Oh), the HBA 
shall perform the action and update this field back to Idle (Oh). 


If software writes to this field to change the state to a state the link is already in (i.e. 
interface is in the active state and a request is made to go to the active state), the HBA 
shall take no action and return this field to Idle. If the interface is in a low power state 
and software wants to transition to a different low power state, software must first bring 
the link to active and then initiate the transition to the desired low power state. 
Aggressive Slumber / Partial (ASP): When set to ‘1’, and ALPE is set, the HBA shall 
aggressively enter the Slumber state when it clears the PxCl register and the PxSACT 
register is cleared or when it clears the PxSACT register and PxCl is cleared. When 
cleared, and ALPE is set, the HBA shall aggressively enter the Partial state when it 
clears the PxCl register and the PxSACT register is cleared or when it clears the 
PxSACT register and PxCl is cleared. If CAP.SALP is cleared to ‘0’ software shall treat 
this bit as reserved. See section 8.3.1.3 for details. 
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26 of the ASP bit. Software shall only set this bit to ‘1’ if CAP.SALP is set to ‘1’; if 
CAP.SALP is cleared to ‘0’ software shall treat this bit as reserved. See section 8.3.1.3 
for details. 

Drive LED on ATAPI Enable (DLAE): When set to ‘1’, the HBA shall drive the LED 
pin active for commands regardless of the state of POCMD.ATAPI. When cleared, the 
HBA shall only drive the LED pin active for commands if POCMD.ATAPI set to ‘0’. See 
section 10.10 for details on the activity LED. 

Device is ATAPI (ATAPI): When set to ‘1’, the connected device is an ATAPI device. 
This bit is used by the HBA to control whether or not to generate the desktop LED when 
commands are active. See section 10.10 for details on the activity LED. 


Reserved 


External SATA Port (ESP): When set to '1', indicates that this port’s signal connector 
is externally accessible on a signal only connector. When set to '1', CAP.SXS shall be 
Hwlnit 


25 


24 


Aggressive Link Power Management Enable (ALPE): When set to ‘1’, the HBA shall 
aggressively enter a lower link power state (Partial or Slumber) based upon the setting 
20 


23:22 


21 set to '1'. When cleared to ‘0’, indicates that this port’s signal connector is not externally 

accessible on a signal only connector. ESP is mutually exclusive with the HPCP bit in 
this register. 

Cold Presence Detection (CPD): If set to ‘1’, the platform supports cold presence 

20 HwInit detection on this port. If cleared to ‘0’, the platform does not support cold presence 

detection on this port. When this bit is set to ‘1, POCMD.HPCP should also be set to 


‘V. 
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Bit_| Type | Reset | Description 
Mechanical Presence Switch Attached to Port (MPSP): If set to ‘1’, the platform 
supports an mechanical presence switch attached to this port. If cleared to ‘0’, the 
platform does not support a mechanical presence switch attached to this port. When 
this bit is set to ‘1’, POCMD.HPCP should also be set to ‘1’. 

Hot Plug Capable Port (HPCP): When set to ‘1’, indicates that this port's signal and 
power connectors are externally accessible via a joint signal and power connector for 
blindmate device hot plug. When cleared to ‘0’, indicates that this port’s signal and 
power connectors are not externally accessible via a joint signal and power connector. 
Port Multiplier Attached (PMA): This bit is read/write for HBAs that support a Port 
Multiplier (CAP.SPM = ‘1’). This bit is read-only for HBAs that do not support a port 
RW/ Multiplier (CAP.SPM = ‘0’). When set to ‘1’ by software, a Port Multiplier is attached to 
RO the HBA for this port. When cleared to ‘0’ by software, a Port Multiplier is not attached 
to the HBA for this port. Software is responsible for detecting whether a Port Multiplier 
is present; hardware does not auto-detect the presence of a Port Multiplier. 

Cold Presence State (CPS): The CPS bit reports whether a device is currently 
detected on this port via cold presence detection. If CPS is set to ‘1’, then the HBA 
detects via cold presence that a device is attached to this port. If CPS is cleared to ‘0’ , 
then the HBA detects via cold presence that there is no device attached to this port. 
Command List Running (CR): When this bit is set, the command list DMA engine for 
15 RO the port is running. See the AHCI state machine in section 5.3.2 for details on when 
this bit is set and cleared by the HBA. 

FIS Receive Running (FR): When set, the FIS Receive DMA engine for the port is 
running. See section 10.3.2 for details on when this bit is set and cleared by the HBA. 
Mechanical Presence Switch State (MPSS): The MPSS bit reports the state of a 
mechanical presence switch attached to this port. If CAP.SMPS is set to ‘1’ and the 
mechanical presence switch is closed then this bit is cleared to ‘0’. If CAP.SMPS is set 
to ‘1’ and the mechanical presence switch is open then this bit is set to ‘1’. If 
CAP.SMPS is set to ‘0’ then this bit is cleared to ‘0’. Software should only use this bit if 
both CAP.SMPS and POCMD.MPSP are set to ‘1’. 

Current Command Slot (CCS): This field is valid when POCMD.ST is set to ‘1’ and 
shall be set to the command slot value of the command that is currently being issued by 
the HBA. When POCMD.ST transitions from ‘1’ to ‘0’, this field shall be reset to ‘0’. 
After POCMD.ST transitions from ‘0’ to ‘1’, the highest priority slot to issue from next is 
command slot 0. After the first command has been issued, the highest priority slot to 
issue from next is POCMD.CCS + 1. For example, after the HBA has issued its first 
command, if CCS = Oh and POCI is set to 3h, the next command that will be issued is 
from command slot 1. 

07:05 |_RO 
FIS Receive Enable (FRE): When set, the HBA may post received FlSes into the FIS 
receive area pointed to by PxFB (and for 64-bit HBAs, PxFBU). When cleared, 
received FlSes are not accepted by the HBA, except for the first D2H register FIS after 
the initialization sequence, and no FlSes are posted to the FIS receive area. 


19 RO Hwlnit 


18 RO 


17 


16 RO 


14 RO 


13 RO 


12:08 RO 


04 RW 
System software must not set this bit until PXFB (PxFBU) have been programmed with 


a valid pointer to the FIS receive area, and if software wishes to move the base, this bit 
must first be cleared, and software must wait for the FR bit in this register to be cleared. 
Refer to section 10.3.2 for important restrictions on when FRE can be set and cleared. 

Command List Override (CLO): Setting this bit to ‘1’ causes PxTFD.STS.BSY and 
PxTFD.STS.DRQ to be cleared to ‘0’. This allows a software reset to be transmitted to 
the device regardless of whether the BSY and DRQ bits are still set in the PxXTFD.STS 
register. The HBA sets this bit to ‘0’ when PxTFD.STS.BSY and PxTFD.STS.DRQ 


03 RW1 have been cleared to ‘0’. A write to this register with a value of ‘0’ shall have no effect. 


This bit shall only be set to ‘1’ immediately prior to setting the PxCMD.ST bit to ‘1’ from 
a previous value of ‘0’. Setting this bit to ‘1’ at any other time is not supported and will 
result in indeterminate behavior. Software must wait for CLO to be cleared to ‘0’ before 
setting PxCMD.ST to ‘1’. 
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Bit_| Type | Reset |Description 
Power On Device (POD): This bit is read/write for HBAs that support cold presence 
detection on this port as indicated by PxCMD.CPD set to ‘1’. This bit is read only ‘1’ for 


02 ae HBAs that do not support cold presence detect. When set, the HBA sets the state of a 
pin on the HBA to ‘1’ so that it may be used to provide power to a cold-presence 
detectable port. 

Spin-Up Device (SUD): This bit is read/write for HBAs that support staggered spin-up 
via CAP.SSS. This bit is read only ‘1’ for HBAs that do not support staggered spin-up. 

01 RW/ On an edge detect from ‘0’ to ‘1’, the HBA shall start a COMRESET initializatoin 

RO sequence to the device. Clearing this bit to ‘0’ does not cause any OOB signal to be 


sent on the interface. When this bit is cleared to ‘0’ and PxSCTL.DET=0h, the HBA will 
enter listen mode as detailed in section 10.9.1. 

Start (ST): When set, the HBA may process the command list. When cleared, the 
HBA may not process the command list. Whenever this bit is changed from a ‘0’ toa 
‘{’, the HBA starts processing the command list at entry ‘0’. Whenever this bit is 
00 RW changed from a ‘1’ to a ‘0’, the PxCl register is cleared by the HBA upon the HBA 
putting the controller into an idle state. This bit shall only be set to ‘1’ by software after 
PxCMD.FRE has been set to ‘1’. Refer to section 10.3.1 for important restrictions on 
when ST can be set to ‘1’. 


3.3.8 Offset 120h: POTFD — Port 0 Task File Data 


This is a 32-bit register that copies specific fields of the task file when FlSes are received. The FlSes that 
contain this information are: 

e D2H Register FIS 

e PIO Setup FIS 

e Set Device Bits FIS (BSY and DRQ are not updated with this FIS) 


Bit_| Type | Reset |Description 
S765) O's 20S | RCSeICO aa es  e 
15:08 | RO | 0 __| Error (ERR): Contains the latest copy of the task file error register. 


Status (STS): Contains the latest copy of the task file status register. Fields of note in 
this register that affect AHCI hardware operation are: 


Bit Field Definition 
7 BSY Indicates the interface is busy 
07:00 RO : cs Command specific 


DRQ Indicates a data transfer is requested 
cs Command specific 
ERR Indicates an error during the transfer. 


The HBA shall update the entire 8-bit field, not just the bits noted above. 
3.3.9 Offset 124h: POSIG — Port 0 Signature 


This is a 32-bit register which contains the initial signature of an attached device when the first D2H 
Register FIS is received from that device. It is updated once after a reset sequence. 


Bit | Reset |Description 


Signature (SIG): Contains the signature received from a device on the first 
D2H Register FIS. The bit order is as follows: 


Bit | Field 
31:24 | LBA High Register 
31:00 FFFFFFFFh 23:16 | LBA Mid Register 


15:08 | LBA Low Register 
07:00 | Sector Count Register 
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3.3.10 Offset 128h: POSSTS — Port 0 Serial ATA Status (SCRO: SStatus) 


This 32-bit register conveys the current state of the interface and host. The HBA updates it continuously 
and asynchronously. When the HBA transmits a COMRESET to the device, this register is updated to its 
reset values. 


Bit_| Type | Reset |Description 
D112 sl ROW |e 20 WIRES OIC a i et | 


Interface Power Management (IPM): Indicates the current interface state: 


Oh Device not present or communication not established 
41-08 RO 1h Interface in active state 

. 2h Interface in Partial power management state 
6h Interface in Slumber power management state 


All other values reserved 
Current Interface Speed (SPD): Indicates the negotiated interface communication 
speed. 


Oh Device not present or communication not established 
th Generation 1 communication rate negotiated 
2h Generation 2 communication rate negotiated 


07:04 RO 


All other values reserved 
Device Detection (DET): Indicates the interface device detection and Phy state. 


Oh No device detected and Phy communication not established 
Device presence detected but Phy communication not established 
03:00 RO Device presence detected and Phy communication established 
Phy in offline mode as a result of the interface being disabled or running in a 
BIST loopback mode 


All other values reserved 
3.3.11 Offset 12Ch: POSCTL — Port 0 Serial ATA Control (SCR2: SControl) 


This is a 32-bit read-write register by which software controls SATA capabilities. Writes to this register 
result in an action being taken by the host adapter or interface. Reads from the register return the last 
value written to it. 


| Bit_| Type | Reset | Description 

| 31:20 | RO | 0 | Reserved 

| 19:16 | RO | 0h | Port Multiplier Port (PMP): This field is not used by AHCI. 

| 15:12 | RO | Oh _ | Select Power Management (SPM): This field is not used by AHCI 


Interface Power Management Transitions Allowed (IPM): Indicates which power 
states the HBA is allowed to transition to. If an interface power management state is 
disabled, the HBA is not allowed to initiate that state and the HBA must PMNAKp any 
request from the device to enter that state. 
11:08 RW Oh Oh No interface restrictions 

th Transitions to the Partial state disabled 

2h Transitions to the Slumber state disabled 

3h Transitions to both Partial and Slumber states disabled 
All other values reserved 


Speed Allowed (SPD): Indicates the highest allowable speed of the interface. 
Oh No speed negotiation restrictions 
07:04 RW Oh th Limit speed negotiation to Generation 1 communication rate 
: 2h Limit speed negotiation to a rate not greater than Generation 2 
communication rate 
All other values reserved 
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Device Detection Initialization (DET): Controls the HBA’s device detection and 
interface initialization. 


Oh No device detection or initialization action requested 

ih Perform interface communication initialization sequence to establish 
communication. This is functionally equivalent to a hard reset and results in 
the interface being reset and communications reinitialized. While this field is 
1h, COMRESET is transmitted on the interface. Software should leave the 
DET field set to 1h for a minimum of 1 millisecond to ensure that a 
COMRESET is sent on the interface. 
Disable the Serial ATA interface and put Phy in offline mode. 


All other values reserved 


This field may only be modified when POCMD.ST is ‘0’. Changing this field while the 
POCMD.ST bit is set to ‘1’ results in undefined behavior. When POCMD.ST is set to ‘1’, 
this field should have a value of Oh. 


Note: It is permissible to implement any of the Serial ATA defined behaviors for 
transmission of COMRESET when DET=1h. 
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3.3.12 Offset 130h: POSERR — Port 0 Serial ATA Error (SCR1: SError) 
Type | Reset |Description 


Diagnostics (DIAG) - Contains diagnostic error information for use by diagnostic 
software in validating correct operation or isolating failure modes: 


Bit 


31:16 


31:27 | Reserved 

26 Exchanged (X): When set to one this bit indicates a COMINIT signal 
was received. This bit is reflected in the POIS.PCS bit. 
Unknown FIS Type (F): Indicates that one or more FISs were received 
25 by the Transport layer with good CRC, but had a type field that was not 
recognized/known. 
Transport state transition error (T): Indicates that an error has 
24 occurred in the transition from one state to another within the Transport 
layer since the last time this bit was cleared. 
Link Sequence Error (S): Indicates that one or more Link state machine 
23 error conditions was encountered. The Link Layer state machine defines 
the conditions under which the link layer detects an erroneous transition. 
Handshake Error (H): Indicates that one or more R_LERR handshake 
RWC response was received in response to frame transmission. Such errors 
may be the result of a CRC error detected by the recipient, a disparity or 
8b/10b decoding error, or other error condition leading to a negative 
handshake on a transmitted frame. 
CRC Error (C): Indicates that one or more CRC errors occurred with the 
Link Layer. 
Disparity Error (D): This field is not used by AHCI. 
10B to 8B Decode Error (B): Indicates that one or more 10B to 8B 
decoding errors occurred. 
Comm Wake (W): Indicates that a Comm Wake signal was detected by 
the Phy. 
Phy Internal Error (I): Indicates that the Phy detected some internal 
error. 
PhyRdy Change (N): Indicates that the PhyRdy signal changed state. 
This bit is reflected in the POIS.PRCS bit. 
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Bit_| Type | Reset |Description 
Error (ERR): The ERR field contains error information for use by host software in 
determining the appropriate response to the error condition. 


15:12 | Reserved 

Internal Error (E): The host bus adapter experienced an internal error 
that caused the operation to fail and may have put the host bus adapter 
into an error state. The internal error may include a master or target 
abort when attempting to access system memory, an elasticity buffer 
overflow, a primitive mis-alignment, a synchronization FIFO overflow, 
and other internal error conditions. Typically when an internal error 
occurs, a non-fatal or fatal status bit in the PxIS register will also be set 
to give software guidance on the recovery mechanism required. 

Protocol Error (P): A violation of the Serial ATA protocol was detected. 
Persistent Communication or Data Integrity Error (C): A 
communication error that was not recovered occurred that is expected to 
15:00 | RWC be persistent. Persistent communications errors may arise from faulty 
interconnect with the device, from a device that has been removed or 
has failed, or a number of other causes. 

Transient Data Integrity Error (T): A data integrity error occurred that 
was not recovered by the interface. 

Reserved 

Recovered Communications Error (M): Communications between the 
device and host was temporarily lost but was re-established. This can 
arise from a device temporarily being removed, from a temporary loss of 
Phy synchronization, or from other causes and may be derived from the 
PhyNRdy signal between the Phy and Link layers. 

Recovered Data Integrity Error (I): A data integrity error occurred that 
was recovered by the interface through a retry operation or other 
recovery action. 


3.3.13 Offset 134h: POSACT — Port 0 Serial ATA Active (SCR3: SActive) 
Bit_| Type | Reset |Description 


Device Status (DS): This field is bit significant. Each bit corresponds to the TAG and 
command slot of a native queued command, where bit 0 corresponds to TAG 0 and 
command slot 0. This field is set by software prior to issuing a native queued command 
for a particular command slot. Prior to writing PxCI[TAG] to ‘1’, software will set 
DS[TAG] to ‘1’ to indicate that a command with that TAG is outstanding. The device 
clears bits in this field by sending a Set Device Bits FIS to the host. The HBA clears 
31:0 | RW1 bits in this field that are set to ‘1’ in the SActive field of the Set Device Bits FIS. The 
HBA only clears bits that correspond to native queued commands that have completed 
successfully. 


Software should only write this field when PXCMD.ST is set to ‘1’. This field is cleared 
when PxCMD.ST is written from a ‘1’ to a ‘0’ by software. This field is not cleared by a 
COMRESET or a software reset. 


Commands Issued (Cl): This field is bit significant. Each bit corresponds to a 
command slot, where bit 0 corresponds to command slot 0. This field is set by software 
to indicate to the HBA that a command has been built in system memory for a 
command slot and may be sent to the device. When the HBA receives a FIS which 
31:0 | RW1 clears the BSY, DRQ, and ERR bits for the command, it clears the corresponding bit in 
this register for that command slot. Bits in this field shall only be set to ‘1’ by software 
when PxCMD.ST is set to ‘1’. 


This field is also cleared when PxCMD.ST is written from a ‘1’ to a ‘0’ by software. 
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3.3.15 Offset 13Ch: POSNTF — SNotification 


This register is used to determine if asynchronous notification events have occurred for directly connected 
devices and devices connected to a Port Multiplier. 


| Bit_| Type | Reset |Description °° 
31:16 | RO_| Oh | Reserved 


PM Notify (PMN): This field indicates whether a particular device with the corresponding 
PM Port number issued a Set Device Bits FIS to the host with the Notification bit set. 
PM Port Oh sets bit 0 
15:0 | RWC | Oh PM Port Fh sets bit 15 
Individual bits are cleared by software writing 1’s to the corresponding bit positions. 
This field is reset to default on a HBA Reset, but it is not reset by COMRESET or 
software reset. 


3.3.16 Offset 140h: Reserved for FIS-based Switching 
This register is reserved for the Port Multiplier FlS-based switching definition. 
3.3.17 Offset 170h to 17Fh: POVS — Vendor Specific 


The registers at offset 170h to 17Fh are vendor specific. 
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4 System Memory Structures 


4.1 HBA Memory Space Usage 


Most communication between software and an SATA device is through the HBA via system memory 
descriptors, which indicates the status of all received and sent FlSes, as well as pointers for data 
transfers. Some additional communication is done via registers in the HBA, for each port and for global 
control. 


A visual breakdown of the HBA memory space is shown in Figure 4. 


Figure 4: HBA Memory Space Usage 
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4.2 Port Memory Usage 


There are two descriptors per port that are used to convey information. One is the FIS descriptor, which 
contains FlSes received from a device, and the other is the Command List, which contains a list of 1 to 32 
commands available for a port to execute. 


The base for each pointer is a 64-bit value (32-bits for HBAs that do not support 64-bit addressing). An 
overview of the overall structure shown in Figure 5, and the following sections describe each area. 


Figure 5: Port System Memory Structures 
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4.2.1. Received FIS Structure 


The HBA uses an area of system memory to communicate information on received FlSes. This structure 
is pointed to by PxFBU and PxFB. The structure is shown in Figure 6. 


Figure 6: Received FIS Organization 


00h 

DSFIS: 

DMA Setup FIS 

1Ch 
20h 

PSFIS: 

PIO Setup FIS 

34h 
40h 

RFIS: 

D2H Register FIS 

54h 
58h 
60h 

UFIS: 

Unknown FIS 
(up to 64 bytes) 
AOh 
Reserved 

FFh 


When a DMA setup FIS arrives from the device, the HBA copies it to the DSFIS area of this structure. 
When a PIO setup FIS arrives from the device, the HBA copies it to the PSFIS area of this structure. 
When a D2H Register FIS arrives from the device, the HBA copies it to the RFIS area of this structure. 


When a Set Device Bits FIS arrives from the device, the HBA copies it to the SDBFIS area of this 
structure. 


When an unknown FIS arrives from the device, the HBA copies it to the UFIS area in this structure, and 
sets PxSERR.DIAG.F, which is reflected in PxIS.UFS when the FIS is posted to memory. A maximum of 
64-bytes of an unknown FIS type may be sent to an HBA. If an unknown FIS arrives that is longer than 
64-bytes, the FIS is considered illegal and is handled as described in section 6.1.2. While the length of 
the FIS is unknown to the HBA, it is expected to be known by system software, and therefore only the 
valid bytes shall be processed by software. The HBA is not required to tolerate receiving an unknown FIS 
when the HBA is expecting a Data FIS from the device or when the HBA is about to transfer a Data FIS to 
the device based on the command protocol being used. 
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The HBA shall take the actions described in 5.3 when a FIS is received, which includes updating the 
Received FIS structure as previously outlined, generating interrupts as appropriate, etc. 


4.2.2. Command List Structure 


Figure 7 shows the command list structure. Each entry contains a command header, which is a 32-byte 
structure that details the direction, type, and scatter/gather pointer of the command. Further details of 
each field are listed below. 


Figure 7: Command List Structure 


15 7 0 
sole bes bes lire Lal 
[pmP RCBRPA) CFL 
PRDBC: PRD Byte Count 
CTBAO: Command Table Base Address 
CTBA_UO: Command Table Base Adr Upper 32-bits 


Each command header has the 
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400h 
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The fields inside the command header are: 


Figure 8: DW 0 - Description Information 
=I is ee eee tt en 

Physical Region Descriptor Table Length (PRDTL): Length of the scatter/gather descriptor 
table in entries, called the Physical Region Descriptor Table. Each entry is 4 DW. A ‘0’ 
represents 0 entries, FFFFh represents 65,535 entries. The HBA uses this field to know when to 
stop fetching PRDs. If this field is ‘0’, then no data transfer shall occur with the command. 

Port Multiplier Port (PMP): Indicates the port number that should be used when constructing 
data FlSes on transmit, and to check against all FlSes received for this command. This value 
must be set to Oh if a Port Multiplier is not attached (PxCMD.PMA is ‘0’). 


Clear Busy upon R_OK (C): When set, the HBA shall clear PxTFD.STS.BSY and 
PxCI.Cl(plssueTag) after transmitting this FIS and receiving R_OK. When cleared, the HBA 
shall not clear PXTFD.STS.BSY nor PxCl.Cl(plssueTag) after transmitting this FIS and receiving 
R_OK. 

BIST (B): When ‘1’, indicates that the command that software built is for sending a BIST FIS. 
The HBA shall send the FIS and enter a test mode. The tests that can be run in this mode are 
outside the scope of this specification. 

Reset (R): When ‘1’, indicates that the command that software built is for a part of a software 
reset sequence that manipulates the SRST bit in the Device Control register. The HBA must 
perform a SYNC escape (if necessary) to get the device into an idle state before sending the 
command. See section 10.4 for details on reset. 

Prefetchable (P): This bit is only valid if the PRDTL field is non-zero or the ATAPI ‘A’ bit is set 
in the command header. When set and PRDTL is non-zero, the HBA may prefetch PRDs in 
anticipation of performing a data transfer. When set and the ATAPI ‘A’ bit is set in the command 
header, the HBA may prefetch the ATAPI command. System software shall not set this bit when 
using native command queuing commands or when using FIS-based switching with a Port 
Multiplier. 


Note: The HBA may prefetch the ATAPI command, PRD entries, and data regardless of the 
state of this bit. However, it is recommended that the HBA use this information from software to 
avoid prefetching needlessly. 

Write (W): When set, indicates that the direction is a device write (data from system memory to 
device). When cleared, indicates that the direction is a device read (data from device to system 
memory). If this bit is set and the P bit is set, the HBA may prefetch data in anticipation of 
receiving a DMA Setup FIS, a DMA Activate FIS, or PIO Setup FIS, in addition to prefetching 


ATAPI (A): When ‘1’, indicates that a PIO setup FIS shall be sent by the device indicating a 
transfer for the ATAPI command. The HBA may prefetch data from CTBAz[ACMD] in 
anticipation of receiving the PIO Setup FIS. 

Command FIS Length (CFL): Length of the Command FIS. A ‘0’ represents 0 DW, ‘4’ 
represents 4 DW. A length of ‘0’ or ‘1’ is illegal. The maximum value allowed is 10h, or 16 DW. 
The HBA uses this field to know the length of the FIS it shall send to the device. 


Figure 9: DW 1 - Command Status 
Ee Bi ih ano A Description 5 eos eS Se 
Physical Region Descriptor Byte Count (PRDBC): Indicates the current byte count that has 
transferred on device writes (system memory to device) or device reads (device to system 
memory). 


For rules on when this field is updated, refer to section 5.4.1 


Figure 10: DW 2 —- Command Table Base Address 


Command Table Descriptor Base Address (CTBA): Indicates the 32-bit physical address of 
the command table, which contains the command FIS, ATAPI Command, and PRD table. This 


address must be aligned to a 128-byte cache line, indicated by bits 06:00 being reserved. 


06:00 


Figure 11: DW 3 — Command Table Base Address Upper 
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Command Table Descriptor Base Address Upper 32-bits (CTBAU): This is the upper 32-bits 


of the Command Table Base. It is only valid if the HBA indicated that it can support 64-bit 
addressing through the S64A bit in the capabilities register, and is ignored otherwise. 


Figure 12: DW 4-7 — Reserved 


|Dword | CC‘éiecription 


| 6 | Reserved 
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4.2.3. Command Table 
Each entry in the command list points to a structure called the command table. 


Figure 13: Command Table 
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Each command contains several fields. The fields break down as follows: 
4.2.3.1 Command FIS (CFIS) 


This is a software constructed FIS. For data transfer operations, this is the H2D Register FIS format as 
specified in the Serial ATA 1.0a specification. The HBA sets PxTFD.STS.BSY, and then sends this 
structure to the attached port. If a Port Multiplier is attached, this field must have the Port Multiplier port 
number in the FIS itself — it shall not be added by the HBA. Valid CFIS lengths are 2 to 16 Dwords and 
must be in Dword granularity. 


4.2.3.2. ATAPI Command (ACMD) 


This is a software constructed region of 12 or 16 bytes in length that contains the ATAPI command to 
transmit if the “A” bit is set in the command header. The ATAPI command must be either 12 or 16 bytes 
in length. The length transmitted by the HBA is determined by the PIO setup FIS that is sent by the 
device requesting the ATAPI command. 
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4.2.3.3 Physical Region Descriptor Table (PRDT) 


This table contains the scatter / gather list for the data transfer. It contains a list of 0 (no data to transfer) 
to up to 65,535 entries. A breakdown of each field in a PRD table is shown below. Item 0 refers to the 
first entry in the PRD table. Item “CH[PRDTL] — 1” refers to the last entry in the table, where the length 


field comes from the PRDTL field in the command list entry for this command slot. 


Figure 14: DW 0 — Data Base Address 


Description 
Data Base Address (DBA): Indicates the 32-bit physical address of the data block. The block 


must be word aligned, indicated by bit 0 being reserved. 


Reserved 


Figure 15: DW 1 — Data Base Address Upper 
Description 
Data Base Address Upper 32-bits (DBAU): This is the upper 32-bits of the data block physical 
address. It is only valid if the HBA indicated that it can support 64-bit addressing through the 
S64A bit in the capabilities register, and is ignored otherwise. 


Figure 16: DW 2 — Reserved 
| Bit |Description —— ——“‘“‘“(C*s‘“‘“CSSTTTCCCCC*d 
31:00 


Figure 17: DW 3 — Description Information 


A RBItS! /Deschptions. sie Le a ee 
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Interrupt on Completion (I): When set, indicates that hardware should assert an interrupt when 
the data block for this entry has transferred, which means that no data is in the HBA hardware. 
Data may still be in flight to system memory (disk reads), or at the device (an R_OK or RLERR 
has yet to be received). The HBA shall set the PxIS.DPS bit after completing the data transfer, 
and if enabled, generate an interrupt. 


30:22 


1 


21:00 


Data Byte Count (DBC): A ‘0’ based value that Indicates the length, in bytes, of the data block. 
A maximum of length of 4MB may exist for any entry. Bit ‘0’ of this field must always be ‘1’ to 
indicate an even byte count. A value of ‘1’ indicates 2 bytes, ‘3’ indicates 4 bytes, etc. 
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5 Data Transfer Operation 
5.1 Introduction 


The data structures of AHCI are built assuming that each port in an HBA contains its own DMA engine, 
that is, each port can be executed independently of any other port. This is a natural flow for software, 
since each device is generally treated as a separate execution thread. It is strongly recommended that 
HBA implementations proceed in this fashion. 


Software presents a list of commands to the HBA for a port, which then processes them. For HBAs that 
have a command list depth of ‘1’, this is a single step operation, and software only presents a single 
command. For HBAs that support a command list, multiple commands may be posted. 


Software posts new commands received by the OS to empty slots in the list, and sets the corresponding 
slot bit in the PxCl register. The HBA continuously looks at PxCl to determine if there are commands to 
transmit to the device. 


The HBA processes the command list in a linear fashion, as described by the HBA state machine below. 
5.2. HBA Controller State Machine (Normative) 


The state machine arcs are in priority order and are not required to be mutually exclusive. For example, if 
both the first arc and second arc of a state are true, the first arc is always taken. Subsequent arcs are not 
evaluated until the previous arc is determined to be false. 


Implementation Note: HBA state variables are used to describe the required externally visible behavior. 
Implementations are not required to have internal state values that directly correspond to these variables. 


5.2.1. Variables 
hCccTimer This variable is used when command completion coalescing is supported by the HBA. 
hCccTimer is decremented by 1h every 1 millisecond. Refer to section 11. 


hCccComplete This variable is incremented when a command completion occurs on a port selected for 
command completion coalescing. Refer to section 11. 


5.2.2 HBA Idle States 


5.2.2.1 H:Init 
H: Init The HBA performs the following actions: 
1. Resets all HBA state machine variables to their reset values, as specified in 
section 5.2.1. 


2. Resets GHC.AE, GHC.IE, and the IS register to their reset values. 
3. Clears GHC.HR to ‘0’ after reset is completed. 


T__ GHC-HRis set toT 
H:WaitForAhciEnable 


NOTE: 
This state is entered asynchronously when GHC.HR is set to ‘1’ from a previous value of ‘0’ and at power- 
up. 
The H:Init state is entered to reset and initialize the entire controller. This state is only entered when the 
HBA powers up or an entire HBA reset is performed. 


Note: GHC.HR shall only be set to ‘1’ by software when GHC.AE is set to ‘1’. The result of an HBA reset 
is to clear GHC.AE to ‘0’ in AHCI implementations where CAP.SAM = ‘0’. After performing an HBA reset, 
GHC.AE should be set to ‘1’ by software before issuing any commands via AHCI mechanisms if 
CAP.SAM = ‘0’. 


5.2.2.2. H:WaitForAhciEnable 
H:WaitForAhciEnable Wait for GHC.AE to be set to ‘1’. 


1. GHC.AE is set to ‘1’ H:Idle 


2. Else H:WaitForAhciEnable 
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The H:WaitForAhciEnable state is entered after a reset. Until GHC.AE is set to ‘1’, any commands 
attempted to be issued via AHCI mechanisms will have indeterminate results. 


5.2.2.3 H:ldle 
H:Idle 


1. _GHC.AE is cleared to ‘0’ H:WaitForAhciEnable 
2. CCC_CTL.EN transitioned from ‘0’ to ‘1’ Ccc:Enable 


3. CCC_CTL.EN = ‘1’ and 1 millisecond has expired since last | + | Ccc:TimerDecrement 
decrement of hCccTimer and (commands are outstanding on 
ports with CCC_PORTS.x = ‘1’ 

4. CCC_CTL.EN = ‘1’ and hCccComplete >= CCC_CTL.CC and | - | Ccc:SetlS 
CCC_CTL.CC != Oh 

5. CCC_CTL.EN = ‘1’ and hCccComplete > 0 and (no commands | — | Ccc:SetlS 
outstanding on ports with CCC_PORTS.x = ‘1’) and 
CCC_CTL.CC != Oh 


The H:Idle state is entered when in normal operation and determines the next operation to perform at a 
global HBA level. 


5.2.2.4 Ccc:Enable 


Ccc:Enable 


The HBA performs the following actions: 
1. Sets hCccTimer to CCC_CTL.TV 
2. Sets hCccComplete to Oh 


1. Unconditional H:Idle 


This state is entered when the command completion coalescing feature is enabled. This state initializes 
the internal variables associated with the command completion coalescing feature. 


5.2.2.5 Ccc:TimerDecrement 


Ccc:TimerDecrement Decrement hCccTimer by 1. 


1. hCccTimer > 0 H:Idle 
Coo:SetlS 


This state is entered to decrement the timer associated with command completion coalescing after 1 
millisecond has elapsed since the last time it was decremented. 


5.2.2.6 Ccc:SetlS 
Ccc:SetlS The HBA performs the following actions: 


1. Clears hCccComplete to on. 
2. Sets hCccTimer to CCC_CTL.TV. 
3. Sets IS.IPS[CCC_CTL.INT] to ‘1’. 


NOTE: 


1. If increments of hCccComplete are targeted for the same cycle as the clearing of hCccComplete to 
Oh, the final value shall be Oh. The additional completions are aggregated into the CCC interrupt that 
will be signaled imminently. 


This state is entered to set status bits in the global interrupt status register. Prior to entering this state, the 
HBA has set the appropriate PxIS bit based on the interrupt cause. 


5.2.2.7 Ccc:Genintr 


Ccc:Genintr HBA generates an interrupt. 
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1. Unconditional —> | Hildle 

NOTE: 

The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


The Ccc:Genintr state is entered to generate an interrupt when an interrupt for the command completion 
coalescing feature should be signaled. See section 10.6 for information on how an HBA generates an 
interrupt. 


5.2.2.8 Em:Reset 


Em:Reset Resets all enclosure management logic and the attached enclosure processor (if 
applicable). After the reset is complete, the HBA sets EM_CTL.CTL.RST to ‘0’. 
1. Unconditional —> | Hi:ldle 
NOTE: 


This state is entered asynchronously when software writes a ‘1’ to EM_CTL.CTL.RST 


This state is entered when software requests that the enclosure management logic be reset. 
5.2.2.9 Em:MsgRecv 


Em:MsgRecv Receive entire message into enclosure management message buffer. After 


message is received successfully set EM_CTL.STS.MR to ‘1’. 


1. _ Unconditional H:Idle 


This state is entered when an enclosure management message is being received. This state finishes 
reception of the message and indicates it to software. 


5.2.2.10 Em:MsgXmit 


Em:MsgXmit Transmit message in enclosure management buffer. After message is transmitted 
successfully clear EM_CTL.CTL.TM to ‘0’. 


1. Unconditional > | H:ldle 


This state is entered when an enclosure management message is being transmitted. This state finishes 
transmission of the message and indicates it to software. 


5.3 HBA Port State Machine (Normative) 


The state machine arcs are in priority order and are not required to be mutually exclusive. For example, if 
both the first arc and second arc of a state are true, the first arc is always taken. Subsequent arcs are not 
evaluated until the previous arc is determined to be false. 


Implementation Note: HBA state variables are used to describe the required externally visible behavior. 
Implementations are not required to have internal state values that directly correspond to these variables. 


5.3.1 Variables 
pUpdateSig This variable is set whenever the HBA needs to update the PxSIG register due to a hard or 


software reset. It is cleared when the D2H Register FIS which updates the signature is 
received. On power-up or reset of the HBA port, pUpdateSig is set to ‘1’. 


plssueTag The plssueTag variable contains the tag of the last command issued. On power-up or reset 
of the HBA port, plssueTag is set to 32. 


pDataTag The pDataTag variable contains the tag of the command to transfer data for next. On power- 
up or reset of the HBA port, pDataTag is cleared to ‘0’. 


pPMP_ The pPMP variable contains the value in the PMP field of the command table of the last 
command FIS transferred to the device. On power-up or reset of the HBA port, pPMP is 
cleared to Oh. 
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pXferAtapi The pXferAtapi variable is set to ‘1’ when a command is issued that had the A bit set for a 
particular transfer. The pXferAtapi variable is cleared to ‘0’ when a Data FIS is transferred to 
the device that contains the ATAPI command from the command list. On power-up or reset 
of the HBA port, pXferAtapi is cleared to ‘0’. 


pPioXfer The pPioXfer variable is set to ‘1’ when a PIO Setup FIS is received. This variable is used 
after a data transfer occurs in order to update the Status register appropriately. 


pPioESts The pPioESts variable is set to the E_Status field of the PIO Setup FIS to be stored until the 
data for the DRQ block is transferred. On power-up or reset of the HBA port, pPioESts is 
cleared to ‘0’. 


pPioErr The pPioErr variable is set to the Error field of the PIO Setup FIS to be stored until the data 
for the DRQ block is transferred. On power-up or reset of the HBA port, pPioErr is cleared 
to ‘0’. 

pPiolbit The pPiolbit variable is set to the | bit of the PIO Setup FIS to be stored until the data for the 
DRQ block is transferred. On power-up or reset of the HBA port, pPiolbit is cleared to ‘0’. 


pDmaXferCnt The pDmaXferCnt variable is set to the DMA transfer count for a particular DMA transfer. 
The DMA transfer may consist of multiple Data FlSes. The pDmaXferCnt variable is 
decremented by the size of a Data FIS on each successful reception of a Data FIS. On 
power-up or reset of the HBA port, pDmaXferCnt is cleared to Oh. An pDmaXferCnt = 
Ohsignals that there was no DMA Setup FIS or PIO Setup FIS corresponding to the data 
transfer and that the transfer lengths should be constructed based on the PRD table entries 
only. 


pCmdTolssue_ This variable is set whenever the currently fetched command still needs to be transmitted to 
the device. It is used by the state machine to ensure the command is actually transmitted to 
the device, especially after a command transmission failure. On power-up or reset of the 
HBA port, pCmdTolssue is cleared to Oh. 


pPrdintr This variable is set whenever the HBA completes a PRD in either the data transmission or 
data reception states. It is used to generate a PRD interrupt at the end of a successful data 
FIS. On power-up or reset of the HBA port, pPrdlntr is clerad to ‘0’. 


pSActive This variable is set to the value of the SActive field in a received Set Device Bits FIS. On 
power-up or reset of the HBA port, pSActive is cleared to Oh. 


This variable is used to track the command slot location the HBA will issue a command from 
pSlotLoc next if one is available in that slot for issue. On power-up or reset of the HBA port, pSlotLoc 
is cleared to Oh. 


5.3.2 Port Idle States 
5.3.2.1 P:Reset 


P:Reset Wait for controller initialization to complete. Apply reset conditions to all port state 
machine variables. 


1. HBA reset complete (HBA not in state H:Init) 


NOTE: 
This state is entered asynchronously when GHC.HR is set to ‘1’ from a previous value of ‘0’ and at power- 
up. 


The P:Reset state is entered when the entire controller is undergoing a reset. This state waits for the 
global controller state to be initialized before continuing. 
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5.3.2.2 P:Init 
P:Init The HBA performs the following actions: 
1. Resets all port state machine variables to their reset values, as specified in 
section 5.3.1. 


2. Resets all port specific register fields (for all ports) except those fields marked 
as Hwinit and the PxFB/PxFBU/PxCLB/PxCLBU registers. 

3. Resets PXTFD.STS to 7Fh and sets pUpdateSig to ‘1’. 

4. Transmits COMRESET to the device if PXCMD.SUD='1’. 


1. _ Unconditional P:NotRunning 


The P:Init state is entered after a controller reset is completed. P:Init initializes all of the state machine 
variables and port specific registers. If cold presence detect is supported as specified in PxCMD.CPD, 
the power to the port is off by default and remains off until software enables power to the port. 


5.3.2.3. P:NotRunning 
P:NotRunning HBA sets plssueTag = 32. HBA sets pSlotLoc = CAP.NCS. 


P:StartComm 


5. PxSCTL.DET written to 1h from any other value and — | P:StartComm 
P pewspst 


8. PxCMD.FRE written to ‘1’ from a ‘0’ and previously processed 
Register FIS is in receive FIFO and PXSERR.DIAG.X = ‘0’ 
9. PXCMD.ST =" Pte 
P:NotRunning 


NOTE: 
1. This state is entered asynchronously when GHC.AE is transitions from ‘1’ to ‘0’. Disabling AHCI mode 
while commands are outstanding has indeterminate results. 


In implementations where CAP.SAM is cleared to ‘0’, software shall set GHC.AE to ‘1’ before accessing 
AHCI registers other than the GHC register. If software accesses AHCI registers other than GHC when 
GHC.AE is cleared to ‘0’ the results are indeterminate. 


The P:NotRunning state is entered when the port specific DMA engines are not running. The DMA 
engines may not be running for numerous reasons, including because the PxXCMD.ST is cleared to ‘0’ or 
the communication link with the device has not been established. 


Software is only allowed to program the PxCMD.FRE, PxCMD.POD, PxSCTL.DET, and PxCMD.SUD 
register bits when PxCMD.ST is set to ‘0’, If software programs these bits in any other state (when 
PxCMD.ST is set to ‘1’), indeterminate results may occur. 


5.3.2.4 P:Cominit 


P:Comlnit HBA sets PxTFD.STS to FFh or 80h. HBA sets PxSSTS.DET to 1h to indicate a 
device is detected but communication is not yet established. HBA sets 
PxSERR.DIAG.X to ‘1’. 


1. _PxIE.PCE is set to ‘1’ P:ComInitSetlS 
P:NotRunning 


NOTE: 
1. This state is entered asynchronously when a COMINIT is received from the device. 


The P:ComlInit state is entered when a COMINIT is received from the device. In this state, the 
PxTFD.STS register and PxSSTS.DET fields are updated to indicate that a device is present. The 
PxSERR.DIAG.X bit is set to ‘1’ to indicate a COMINIT has been received. 
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5.3.2.5 P:ComlnitSetlS 


P:ComlnitSetlS HBA sets IS.IPS(x) to ‘1’. 


1. GHC.IE = ‘1’ P:ComInitGenIntr 


P:NotRunning 


This state is entered when a COMINIT is received and the enable for Port Connect Status change 
interrupts is set to ‘1’. 


5.3.2.6 P:ComlnitGenIintr 


P:ComlnitGenintr HBA generates an interrupt. 


1. _ Unconditional P:NotRunning 


NOTE: 


The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


The P:ComlnitGenIntr state is entered to generate an interrupt for the port after a COMINIT is received 
from the device. See section 10.6 for information on how an HBA generates an interrupt. 


5.3.2.7 P:RegFisUpdate 


P:RegFisUpdate HBA performs the following actions: 
1. HBA updates PxSIG with appropriate fields from D2H Register FIS as outlined 
in 3.3.9, and clears pUpdateSig to ‘0’. 


1. PxCMD.FRE = ‘1’ P:RegFisPostloMem 


P:NotRunning 


The P:RegFisUpdate state is entered to update the PxSIG registers when a D2H Register FIS is received 
while the PxCMD.ST bit is cleared to ‘0’. 


5.3.2.8 P:RegFisPostTtoMem 
P:RegFisPostToMem 


HBA performs the following actions: 

1. HBA posts the Register FIS in the receive FIFO to PxFB[RFIS] 

2. Updates PxTFD.ERR register with value in the Error field of the Register FIS. 
3. Updates PxTFD.STS register with value in the Status field of the Register FIS. 


1. _ Unconditional P:NotRunning 


The P:RegFisPostToMem state is entered to post the initial Register FIS and update the PxTFD register 
once PxCMD.FRE is set to ‘1’. 


5.3.2.9  P:Offline 


P:Offline HBA puts Phy into offline mode and the Phy voltage level is brought to common- 
mode. 


1. _ Unconditional P:NotRunning 


The P:Offline state is entered to place the Phy for the port into offline mode. Offline mode is defined in 
the Serial ATA 1.0a specification. 


5.3.2.10 P:StartBitCleared 


P:StartBitCleared HBA clears PxCl to Oh, PxSACT to Oh, PxCMD.CCS to Oh, and PxCMD.CR to ‘0’. 
HBA clears pDmaXferCnt to Oh. 


1. DMA engines for the port not idle P:StartBitCleared 
2. Unconditional P:NotRunning 


NOTE: 


This state is entered asynchronously when software writes the PxCMD.ST bit to a ‘0’ from a previous value 
of ‘1’ and the HBA is not in state H:Init. 


The P:StartBitCleared state is entered when the PxCMD.ST bit is cleared to ‘0’ from a previous value of 
1. 
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5.3.2.11 P:Idle 
P:Idle HBA sets PxCMD.CR to ‘1’. 


P:SelectCmd 
pCmdTolssue = ‘1’ and CTBA(plssueTag)[R] is set to ‘1’ and CFIS:SyncEscape 
pDmaxXferCnt = ‘0’ 


4. Data FIS received | — | DR:Entry 


5. Non-Data FIS received | — | NDR:Entry 
6. pCmdTolssue = ‘1’ and pDmaXferCnt = ‘0’ CFIS:Xmit 


7. Link layer has negotiated to low power state based on device 
power management request 
[9 Else ——C—‘“‘“‘“‘“CSNN Cd dP le 


The P:Idle state is entered when in normal operation to determine the next thing to do. 
§.3.2.12 P:SelectCmd 
P:SelectCmd HBA sets pSlotLoc = (pSlotLoc + 1) mod (CAP.NCS + 1). 


1. PxCl.Cl(pSlotLoc) = ‘0’ P:SelectCmd 
2. Else (command is selected) P:FetchCmd 


The P:SelectCmd state is entered to select the next command to issue to the device. 


Note: The search for a new command to issue is described as an iterative process, where each clock 
checks a particular Cl value. It is shown this way to explicitly indicate the next command to be sent. An 
implementation may optimize the search in a single clock, so long as the correct command is selected. 


5.3.2.13 P:FetchCmd 


P:FetchCmd The HBA performs the following actions in the order specified: 
HBA fetches command header from PxCLB[CH(pSlotLoc)] 
HBA sets plssueTag = pSlotLoc 

HBA sets PxCMD.CCS = pSlotLoc 

HBA sets pCmdTolssue = ‘1’ 

HBA may prefetch the command FIS from memory 


1. CTBA(plssueTag) A (ATAPI) = 4" and CTBA(plssueTag).P =2-,| CEs: PretetcnACMp 
(Prefetchable) = 


CTBA(plssueTag).P  (Prefetchable) = | > | CFIS:PrefetchPRD 
Unconditional [> |Pilde | 


NOTE. 

1. The P bit may be ignored by hardware although it is recommended to be observed to avoid 
prefetching unnecessary data. 

2. An HBA implementation may choose to ignore arcs 1 and 2 if it is not desireable to prefetch after the 
command FIS is fetched from memory. 


akwON> 


The P:FetchCmd state is entered to fetch the command header for the next command to issue from 
memory. Note that when a command is selected to be transferred next, an implementation may choose 
to set PXTFD.STS.BSY. The requirement is that PxTFD.STS.BSY must be set before the command is 
issued to the device. 


5.3.2.14 P:StartComm 


Pistaiomm The HBA be link layer to start communication, which involves sending 
COMRESET to device. The HBA resets PXTFD.STS to 7Fh, and sets pUpdateSig 
to ‘1’. 


1. PxSCTL.DET = 1h P:StartComm 


2. Unconditional P:NotRunning 
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NOTE: 
1. Hardware polling to determine if a device is present is an implementation specific detail. A polling 


strategy is not specified in AHCI. 
2.  Itis permissible to implement any of the Serial ATA defined behaviors for transmission of COMRESET 
when DET=1h. 


The P:StartComm state is entered to start communication with the device by issuing a COMRESET. 
5.3.2.15 P:PowerOn 


P:PowerOn 


The HBA drives the appropriate external pin to a level which enables the FET to 
supply power to the device. 


The P:PowerOn state is used to power on a device port. 
5.3.2.16 P:PowerOff 
P:PowerOff 


The HBA drives the appropriate external pin to a level which disables the FET from 
supplying power to the device. 


1. _ Unconditional P:NotRunning 


The P:PowerOff state is used to power off a device port. 


5.3.2.17_ P:PhyListening 
P:PhyListening The HBA sets the Phy into listen mode, as defined in section 10.9.1. 


This state is entered when PXxCMD.SUD is set to ‘0’ from a previous value of ‘1’ and PxSCTL.DET = ‘0’. 


5.3.3 Power Management States 


These states are entered when the HBA is attempting to enter a low power state when the HBA is at an 
idle condition. 


5.3.3.1 PM:Aggr 


PM:Aggr 


__PXGI= Oh or PxSAGT I= Oh > [Pie SSCS 


2. PxCMD.ALPE = ‘1’ and PxCMD.ASP = ‘0’ and CAP.PSC = ‘1’ | > | PM:Partial 


and PxSCTL.IPM != ‘1h’ and PxSCTL.IPM != ‘3h’ 


3._PxCMD.ALPE = ‘1’ and PxCMD.ASP = ‘1’ and CAP.SSC = "1" | > | PM:Slumber 
and PxSCTL.IPM I= ‘2h’ and PxSCTL.IPM != ‘3h’ 
4 Ese Pile 


In this state, the HBA determines whether it can place the link into a low power state if aggressive power 
management is enabled. The link can only be placed into a low power state if both the PxCl and the 
PxSACT registers are cleared to zero which indicates there are no commands outstanding. 


5.3.3.2  PM:ICC 
PM:ICC 


1. Value written by software to PxCMD.ICC was 6h PM:Slumber 
2. Value written by software to PxCMD.ICC was 2h PM:Partial 
[3 Else Pile 


The HBA enters this state when PXCMD.ICC is written when the HBA is idle. If software has requested a 
Slumber or Partial power management request, the HBA will attempt to bring the link to that power state. 


5.3.3.3 PM:Partial 


PM:Partial HBA attempts to place the link in the Partial interface power management state 


1. Transition to Partial successful PM:LowPower 


ee SSCSC—CCSCSSSSCSCSCS Pele SCSC~*” 
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The HBA is not guaranteed to succeed in placing the link in the Partial interface power management state 
due to a number of reasons including the current value of the PxSSTS.IPM field and whether the device 
responds with PMNAK, to the request. 


5.3.3.4 PM:Slumber 


PM:Slumber HBA attempts to place the link in the Slumber interface power management state 


1. Transition to Slumber successful PM:LowPower 


[2 Else le 


The HBA is not guaranteed to succeed in placing the link in the Slumber power management state due to 
a number of reasons including the current value of the PxSSTS.IPM field and whether the device 
responds with PMNAK, to the request. 


5.3.3.5 PM:LowPower 


PM:LowPower HBA remains in low power state negotiated (Partial or Slumber) 


PMWakeLink 
PM:WakeLink 
PM:WakeLink 


The HBA may bring the link to the active state based on a device request, an explicit software request 
(writing the PXCMD.ICC register to 1h), or to transfer a new command. 


5.3.3.6 PM:WakeLink 


PM:WakeLink HBA resumes to active state on the link 


1. Resume from power management state fails P:NotRunning 


The HBA resumes from the Partial or Slumber power management mode by following the OOB 
sequences described in the Serial ATA 1.0a specification. 


5.3.4 Non-Data FIS Receive States 
5.3.4.1. NDR:Entry 


NDR:Entry Receive up to 64 bytes of FIS into internal FIFO. 


1. Reception error (FIS reception failed) ERR:Non-fatal 


2. FIS is longer than 64 bytes ERR:Fatal 
NDR:Accept 


This state is entered when the HBA has received a non-Data FIS. 
5.3.4.2 NDR:Accept 
NDR:Accept HBA accepts the FIS with a status of R_OK. 
1. FIS type is D2H Register FIS or PIO ae FIS and 
(PxTFD.STS.BSY = ‘0’ and PXTFD.STS.DRQ = ‘0’) 
FIs Type is D2H Register and PxCMD.ST=0 Ez Besee Und 


pS PMDFRESD > LN” 


7. FIS Type is DMA Setup | > | DmaSet:Entry 


8. FIS Type is BIST Activate and far-end loopback is enabled in BIST:FarEndLoopback 
the FIS 

9. FIS Type is BIST Activate and far-end loopback is not enabled BIST:TestOngoing 
in the FIS 


10. FIS Type is PIO Setup PIO:Entry 
11. Else (FIS type is unknown) UFIS:Entry 
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NOTE: 


1. Software shall set PXCMD.FRE to ‘1’ prior to setting PXCMD.ST to ‘1’. Setting PxCMD.ST to ‘1’ when 
PxCMD.FRE is cleared to ‘0’ will cause indeterminate results. 


In this state, the non-Data FIS received has been verified to be valid. If the FIS is a Register FIS or PIO 
Setup FIS and PxTFD.STS.BSY and PxTFD.STS.DRQ are cleared, the HBA accepts the FIS with R_LOK 
but does not perform any updates based on it; see section 6.1.2. 


5.3.5 Command Transfer States 
5.3.5.1 CFIS:SyncEscape 
CFIS:SyncEscape 


HBA performs a SYNC escape until the interface is quiescent. HBA sets 
pUpdateSig to ‘1’ to flag that the signature needs to be updated. 


1. _ Unconditional CFIS:Xmit 


This state is entered when a reset FIS has been constructed to send to the device. In this state, the HBA 
shall perform a SYNC escape on the interface until the interface is quiescent. 


5.3.5.2 CFIS:Xmit 


CFIS:Xmit HBA performs the following actions in the order specified: 
1. HBA sets PxTFD.STS.BSY to ‘1’ 
2. Sets pDataTag = plssueTag, pPMP = CTBA(plssueTag)[PMP], pXferAtapi = 
CTBA(plssueTag)[A], pDmaXferCnt = 0 
3. Fetches command FIS from CTBA(plssueTag)[CFIS] if not prefetched. 
4. Transmits FIS to device, with a length given by CTBA(plssueTag)[CFL] 


1. _X_RDY/X_RDY collision on interface, delay FIS transfer |> |PiIlde | 
2. SYNC escape received for FIS ERR:SyncEscapeRecv 
3. R_OK status received for FIS CFIS:Success 


4. Else (FIS transfer failed) ERR:Non-fatal 


This state is entered to transmit a command FIS to the device. If an X_RDY/X_RDY collision occurs on 
the interface, the HBA will return to idle and attempt the FIS transmission again at a later time. If the FIS 
transmission starts but then fails for some reason, non-fatal error bits will be set in the non-fatal error 
state and the HBA will attempt to retransmit the command FIS at a later time. 


5.3.5.3 CFIS:Success 
CFIS:Success HBA clears pCmdTolssue to ‘0’. 


1. CTBA(plssueTag).B (BIST) = ‘1’ BIST:TestOngoing 
2. CTBA(plssueTag).C (Clear BSY upon R_OK) = ‘1’ CFIS:ClearCl 


3. CTBA(plssueTag).A (ATAPI) = ‘1’ and CTBA(plssueTag).P =. | CElS:PrefetchACMD 
(Prefetchable) = ‘1’ 


4. CTBA(plssueTag).P (Prefetchable) = ‘1’ GFIS;PretetehP RD 


Pde 
NOTE: 


1. The P bit may be ignored by hardware although it is recommended to be observed to avoid 
prefetching unnecessary data. 

2. An HBA implementation may choose to ignore arcs 3 and 4 if it is not desired to prefetch after the 
command FIS is sent or if the prefetch has already been done. 


This state is entered after a command FIS is transferred successfully. 
5.3.5.4 CFIS:ClearCl 


CFIS:ClearCl HBA clears PxTFD.STS.BSY to ‘0’. HBA clears PxCl.Cl(plssueTag) to ‘0’. HBA 
sets plssueTag to 32. 


1. CCC_PORTS.x = ‘1’ and PxSACT.DS(plssueTag) = ‘0’ CFIS:Ccc 


2. Unconditional PM:Aggr 
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This state is entered when the HBA successfully transmits a command FIS to the device and the Clear 
Bsy upon R_OK (C) bit is set in the command header. The PRD byte count is not required to be updated 
in this state since no data transfer can take place. 


5.3.5.5 CFIS:Ccc 
CFIS:Ccc HBA increments hCccComplete by 1. 


1. Unconditional PM:Aggr 


This state increments the hCccComplete variable that tracks the number of commands completed on 
ports doing command completion coalescing. 


5.3.5.6 CFIS:PrefetchACMD 


CFIS:PrefetchACMD HBA may prefetch all or part of the ATAPI command at CTBA(pDataTag)[ACMD] 
based on implementation specific algorithm and buffer space. 


1. CTBA(plssueTag).P  (Prefetchable) = ‘1’ CRIS Freicicnk RD 
(2. Else —“‘“CS*S*S*S*S*™*™;™C™C™Cd YT Pl@ Cid 


NOTE: 
1. The P bit may be ignored by hardware although it is recommended to be observed to avoid 
prefetching unnecessary data. 


This state is entered after a command FIS has been transferred for an ATAPI command in order to 
prefetch the ATAPI command to be sent to the device. 


5.3.5.7 CFIS:PrefetchPRD 


CFIS:PrefetchPRD HBA prefetches some number of PRDs, based on implementation specific algorithm 
and buffer space. 


CH(plssueTag).W (Write) set | > | CFIS:PrefetchData 


ae ee 


This state is entered after a command FIS has been transferred and there are PRD entries that can be 
prefetched for the command. 


5.3.5.8 CFIS:PrefetchData 
CFIS:PrefetchData 


HBA may prefetch some amount of data, based on implementation specific 
algorithm and buffer space available. 


T__Unconattional [See 


This state is entered after a command FIS has been transferred and there is data to be written to the 
device that can be prefetched. 


5.3.6 ATAPI Command Transfer States 


The states in this portion of the state machine are responsible for transmitting the ACMD field to the 
device. 


5.3.6.1 ATAPI:Entry 


ATAPI:Entry The HBA constructs a Data FIS with the minimum of pDmaXferCnt bytes or 16 
bytes of data fetched from CTBA(pDataTag)[ACMD] as necessary. The PMP field 
of the Data FIS is set to the value in PXCLB[CH(pDataTag)][PMP]. HBA transmits 
the Data FIS to the device. HBA clears pXferAtapi to ‘0’. 


1. Error occurred on transmission ERR:Fatal 


2. Else (transmission successful, R_OK received) PIO:Update 


This state is entered to transmit the ATAPI command to the device. 
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5.3.7 D2H Register FIS Receive States 
5.3.7.1 RegFIS:Entry 
RegFIS:Entry 


HBA performs the following actions in order: 

1. Copies Register FIS to system memory at PxFB[RFIS]. 

2. Updates PxTFD.ERR register with value in the Error field of the Register FIS 
3. Updates PxTFD.STS register with value in the Status field of the Register FIS 


1. PxTFD.STS.ERR = ‘1’ — | ERR:Fatal 
— | RegFIS:ClearCl 


2. PxTFD.STS.BSY ='0’ and PxTFD.STS.DRQ ='0’ 


RegFS:UpdateSig 


This state is entered after a valid D2H Register FIS arrives from the device. The purpose of this state is 
to update HBA registers and system memory appropriately based on the D2H Register FIS received. 


5.3.7.2 RegFIS:ClearCl 


RegFIS:ClearCl PxCLB[CH(plssueTag)][PRDBC] updated to reflect total number of bytes 
successfully transferred. HBA clears PxCl.Cl(plssueTag) to ‘0’. HBA sets 
plssueTag to 32. 


1. CCC_PORTS.x = ‘1’ and PxSACT.DS(plssueTag) = ‘0’ RegFIS:Ccc 


2. Register FIS | bit set RegFIS:Setintr 
RegFIS:UpdateSig 


This state is entered to clear the command issue bit in the PxCl register corresponding to the last 
command issued. In this state the HBA updates the PRD byte count according to rules in section 5.4.1, 
clears PxCl.Cl(plssueTag) to ‘0’ and sets plssueTag to 32. 


5.3.7.3. RegFIS:Ccc 
RegFIS:Ccc HBA increments hCccComplete by 1. 


1. Register FIS | bit set RegFIS:SetIntr 


RegFIS:UpdateSig 


This state increments the hCccComplete variable that tracks the number of commands completed on 
ports doing command completion coalescing. 


5.3.7.4 RegFIS:Setintr 
RegFIS:Setintr HBA sets PxIS.DHRS to ‘1’. 


1. PxIE.DHRE = ‘1’ RegFIS:SetlS 


This state is entered when the interrupt ‘I’ bit is set in the D2H Register FIS received. 
5.3.7.5 RegFIS:SetlS 
RegFIS:SetlS HBA sets IS.IPS(x) to ‘1’. 


1. GHC.IE = ‘1’ RegFIS:GeniIntr 


RegF1S:UpdateSig 


This state is entered when the interrupt ‘I’ bit is set in the D2H Register FIS received and the enable for 
D2H Register FIS interrupts is set. 


5.3.7.6 RegFIS:Genintr 
RegFIS:Genlntr HBA generates an interrupt. 


1. Unconditional RegFIS:UpdateSig 


NOTE: 


The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


The RegFIS:GenIntr state is entered to generate an interrupt for the port after a Register FIS interrupt has 
occurred. See section 10.6 for information on how an HBA generates an interrupt. 
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5.3.7.7 RegFIS:UpdateSig 
RegFIS:UpdateSig 


1. _pUpdateSig = ‘1’ RegFIS:SetSig 


The RegFIS:UpdateSig state is entered to check whether the PxSIG register needs to be updated. 
5.3.7.8 RegFIS:SetSig 


RegFIS:SetSig HBA updates PxSIG with appropriate fields from D2H Register FIS as outlined in 
3.3.9, and clears pUpdateSig to ‘0’ 


1. Unconditional —_| PM:Aggr 
The RegFIS:SetSig state updates the PxSIG register. 
5.3.8 PIO Setup Receive States 
5.3.8.1 PlO:Entry 


PIO:Entry HBA performs the following actions in order: 

Copies the PIO Setup FIS to system memory at PxFB[PSFIS]. 
Sets pPioXfer to ‘1’ 

Sets pPioESts to E_Status field of the FIS 

Sets pPioErr to Error field of the FIS 

Sets pPiolbit to value of | bit in the FIS 

Sets pDmaXferCnt to Transfer Count field of the FIS 

Sets PxTFD.STS register to Status field of the FIS 


D bit in the FIS is cleared to ‘0’ and pXferAtapi is cleared to ‘0’ 
(Data FIS should be transmitted) 
D bit in the FIS is cleared to ‘0’ and pXferAtapi is set to ‘1’ 
(ATAPI command should be transmitted) 
4. Else (Data FIS will be received from device) —————~it> [Pde ———S—~SY 
This state receives a PIO Setup FIS and updates the appropriate state based on the PIO Setup FIS. 


5.3.8.2 PlO:Update 


PIO:Update HBA performs the following actions: 
1. Updates PxTFD.STS with pPioESts 
2. Updates PxTFD.ERR with pPioErr 
3. Clears pPioXfer = ‘0’ 


2. PxTFD.STS.BSY = ‘0’ and PxTFD.STS.DRQ = ‘0’ 
[4 fe C—~—“—sSCCCCCCTCCCC‘idU‘S | PidleSC—~—C~SCSY 


This state updates appropriate registers after the PIO transfer has completed. 
5.3.8.3 PlO:ClearCl 


PIO:ClearCl PxCLB[CH(plssueTag)][PRDBC] updated to reflect total number of bytes 
successfully transferred. The HBA clears PxCl.Cl(plssueTag) to ‘0’ and sets 
plssueTag to 32. 


1. .CCC_PORTS.x = ‘1’ and PxSACT.DS(plssueTag) = ‘0’ PIO:Ccc 


NOaARWON> 


2. _pPiolbit = ‘1’ PIO:Setintr 
PM:Aggr 


This state is entered to mark the current command as completed and allow the HBA to fetch a new 
command. In this state, the PRD byte count is updated according to the rules in section 5.4.1. 


5.3.8.4 PlO:Ccc 


PIO:Ccc HBA increments hCccComplete by 1. 
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1. pPiolbit = ‘1’ PIO:Setintr 
PM:Aggr 


This state increments the hCccComplete variable that tracks the number of commands completed on 
ports doing command completion coalescing. 


5.3.8.5 PlO:Setintr 
PIO:Setintr Set PxIS.PSS to ‘1’ 


1. PxlE.PSE = ‘1’ PIO:SetIS 


This state is entered when the PIO Setup FIS has the interrupt ‘I’ bit set. 
5.3.8.6 PlO:SetIS 
DR:PrdSetlS HBA sets IS.IPS(x) to ‘1’. 


1. GHC.IE = ‘1’ PIO:GenIntr 


This state is entered to set the interrupt for this port on the controller. 
5.3.8.7 PlO:Genlintr 
PIO:Genlintr HBA generates an interrupt. 


1. Unconditional PM:Aggr 


NOTE: 


The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


This state is entered to generate an interrupt for the port. See section 10.6 for information on how an 
HBA generates an interrupt. 


5.3.9 Data Transmit States 
5.3.9.1 DX:Entry 


DX:Entry The HBA constructs a Data FIS for command list entry pDataTag. The PMP field of 
the Data FIS is set to the value in PXCLB[CH(pDataTag)][PMP]. The HBA fetches 
PRDs and data from locations specified in the pDataTag command list entry. The 


HBA clears pPrdIntr to ‘0’. 
1. No data to transmit and pPioXfer = ‘1’ 
2. No data to transmit and pPioxfer = ‘0’ [> |Pildle | 


3. Else 
This state starts to construct a Data FIS to transmit to the device. This state is entered after a PIO Setup, 
DMA Activate, or DMA Setup FIS is received. 


5.3.9.2 DX:Transmit 


DX:Transmit HBA transmits the Data FIS to the device. Continue to fetch PRDs and data as 
necessary to complete the Data FIS. For each PRD entry processed, if R_OK is 
received for all the FlSes containing the data for that PRD entry and the ‘I’ bit is set 
in the PRD entry, then set pPrdIntr to ‘1’. 


1. SYNC escape received for Data FIS — | ERR:SyncEscapeRecv 
. Transmission failed — | ERR:Fatal 
3. End of PRD table reached, or maximum Data FIS length of | + | DX:UpdateByteCount 
8KB has been transferred. 
NOTE: 
1. If the DMAT primitive is received from the device, it is recommended that this primitive be ignored and 
data transmission be continued. 


This state transmits a Data FIS to the device. The HBA will fetch PRDs and data as necessary to 
complete the Data FIS. 
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5.3.9.3 DX:UpdateByteCount 
DX:UpdateByteCount 


HBA performs the following actions: 

1. Optionally increments PxCLB[CH(pDataTag)][PRDBC] by size of Data FIS 
transferred. 

Decrements pDmaXferCnt by size of Data FIS transferred. 

— | DX:PrdSetlntr 

PIO:Update 

P:Idle 


2. 


1. pPrdintr = ‘1’ 
2. pPioXfer = ‘1’ 
3. Else 


This state updates transfer byte counts based on the Data FIS that was successfully transmitted. Update 
of the PRD byte count is optional, refer to section 5.4.1. 


5.3.9.4 DX:PrdSetintr 


HBA sets PxIS.DPS to ‘1’. HBA clears pPrdintr to ‘0’. 
(3. Else Pile 


The HBA enters this state when a PRD interrupt needs to be generated. 
5.3.9.5 DX:PrdSetlS 
DX:PrdSetlS HBA sets IS.IPS(x) to ‘1’. 


1. GHC.IE = ‘1’ 
F => 


DX:PrdGenIntr 


2. pPioXfer = PIO:Update 


3 EkeSSOSCSCSCSCSSSSSSCCCOCSCSC“‘“‘C‘* SC Pilgle SSCS 


The HBA enters this state to set an interrupt on the controller for this port. 
5.3.9.6 DX:PrdGenlintr 


HBA generates an interrupt. 
1. pPioXfer = ‘1’ PIO:Update 
2. Else P:Idle 
NOTE: 
The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


This state is entered to generate an interrupt. See section 10.6 for information on how an HBA generates 
an interrupt 


5.3.10 Data Receive States 
5.3.10.1  DR:Entry 
DR:Entry HBA clears pPrdintr to ‘0’. 


1. PMP field in the Data FIS does not equal pPMP ERR:Non-fatal 


This state is entered when a Data FIS is received. This state checks to make sure the Port Multiplier Port 
field is valid. 


5.3.10.2 DR:Receive 


DR:Receive HBA fetches PRD entries from the command list entry for pDataTag as necessary 
and transfers data from FIS to system memory. For each PRD entry processed, if 
a valid CRC is received for all the FlSes containing the data for that PRD entry and 
the ‘I’ bit is set in the PRD entry, then set pPrdintr to ‘1’. 
Data FIS reception successful (Link layer returned R_OK to ERR:Non-fatal 
device) and more data arrived than could fit in PRD table 


eee 
2. Data FIS reception successful (Link layer returned R_OK to DR:UpdateByteCount 
device) 
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3. Else (Data FIS reception failed) ERR:Fatal 


This state is entered when a Data FIS is received. The state transfers the data in the FIS to system 
memory until there is no data left to transfer or the end of the PRD table is reached. 


5.3.10.3  DR:UpdateByteCount 
DR:UpdateByteCount 


HBA accepts FIS with status of ROK. HBA optionally increments 
PxCLB[CH(pDataTag)][PRDBC] by number of bytes transferred to system memory. 
HBA decrements pDmaXferCnt by number of bytes transferred to system memory. 


1._pPrdintr = "1" Dx:PrdSetintr 


2. pPioXfer = ‘1’ — | PlO:Update 
3. Else —> | P:ldle 


This state is entered after the appropriate number of bytes in a Data FIS have been transferred to system 
memory and the Data FIS CRC has been verified as correct. Update of the PRD byte count is optional, 
refer to section 5.4.1. 


5.3.11 DMA Setup Receive States 
5.3.11.1 DmaSet:Entry 


DmaSet:Entry The HBA performs the following actions: 
1. HBA stores TAG field from the DMA Setup FIS in pDataTag 
2. HBA stores TransferCount field from the DMA Setup FIS in pDmaXferCnt 
3. HBA writes the FIS to system memory at PxFB[DSFIS] 


1. | bit in the FIS is set to ‘1’ DmaSet:SetIntr 


DmaSet:AutoActivate 


This state is entered when a correctly formed DMA Setup FIS is received. 
5.3.11.2 DmaSet:Setintr 


DmaSet:Setintr HBA sets PxIS.DSS to ‘1’. 


1. PxlE.DSE = ‘1’ DmaSet:SetlS 


This state is entered when a DMA Setup FIS is received that has the | bit set. 
5.3.11.3 DmaSet:SetlS 
DmaSet:Setintr HBA sets IS.IPS(x) to ‘1’. 


1. GHC.IE = ‘1’ DmaSet:GenIntr 


DmaSet:AutoActivate 


In this state, the HBA sets the interrupt status bit for this port on the controller. 
5.3.11.4 DmaSet:Genlntr 


DmaSet:Genlntr HBA generates an interrupt. 
NOTE: 
The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


This state is entered to generate an interrupt. See section 10.6 for information on how an HBA generates 
an interrupt 


5.3.11.5 DmaSet:AutoActivate 
DmaSet:AutoActivate 


1. CH(pDataTag).W is set to ‘1’ and A bit in the FIS is set to ‘1’ DX:Entry 
> |Pide 


a a en aes 


This state is entered to determine whether a Data FIS should immediately be transmitted to the device. 
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5.3.12 Set Device Bits States 
5.3.12.1 SDB:Entry 


SDB:Entry HBA performs the following actions: 

1. Copies Set Device Bits FIS to system memory at offset PxFB[SDFIS] 

2. Updates PxTFD.STS with non-reserved bits in Status field of FIS 

3. Updates PxTFD.ERR with Error field of FIS 

4. Clears bits in PXSACT that have corresponding bits set in the SActive field of 
the SDB FIS. Sets pSActive to value of SActive field in received FIS. 

5. Clears pDmaXferCnt to ‘0’ 


1. PxTFD.STS.ERR = ‘1’ ERR:Fatal 
2. CAP.SSNTF = ‘1’ and (Notification (N) bit and | bit are both set | — | SDB:Notification 
to ‘1’ in the SDB FIS 


3. | bit is set in the SDB FIS SDB:Setintr 
PM:AggT 


This state receives a Set Device Bits FIS and updates the appropriate state based on the Set Device Bits 
FIS. 


5.3.12.2  SDB:Notification 


SDB:Notification HBA sets to ‘1’ the bit corresponding to the Port Multiplier Port number in the 
received SDB FIS in PXSNTF.PMN. 


1. _ Unconditional SDB:SetIntr 


This state updates the PxSNTF register based on the Port Multiplier Port number received in the Set 
Device Bits FIS. This state is only entered if the received Set Device Bits FIS has the Notification bit set 
and the HBA supports the SNotification register as shown in CAP.SSNTF. 


5.3.12.3  SDB:Setintr 
|3. pSActve="O Pie 


This state is entered when a Set Device Bits FIS with the interrupt bit set was received. 
5.3.12.4 SDB:Ccc 
SDB:Ccc HBA increments hCccComplete by number of bits set to ‘1’ in pSActive. 


1. PxlE.SDBE = ‘1’ SDB:SetlS 


2. Unconditional PM:Aggr 


This state increments the hCccComplete variable that tracks the number of commands completed on 
ports doing command completion coalescing. 


5.3.12.5 SDB:SetlS 
SDB:SetIS HBA sets IS.IPS[x] bit. 


1. GHC.IE bit set SDB:GeniIntr 


2.__pSAetive = 0 > [Pile 
PM:Aggr 


This state is entered to set status bits in the global interrupt status register. Prior to entering this state, the 
HBA has set the appropriate PxIS bit based on the interrupt cause. 


5.3.12.6 SDB:Genlintr 


SDB:GenlIntr HBA generates an interrupt. 
1. pSActive = ‘0’ —> | P:ldle 
2. Unconditional — | PM:Aggr 
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NOTE: 
The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


This state is entered to generate an interrupt for the port. See section 10.6 for information on how an 
HBA generates an interrupt. 


5.3.13 Unknown FIS Receive States 
5.3.13.1 UFIS:Entry 
UFIS:Entry 


HBA performs the following actions in order: 
1. Copies the Unknown FIS to system memory at PxFB[UFIS] 
2. Sets PxIS.UFS to ‘1’ 


1. PxIE.UFE is set to ‘1’ — | UFIS:SetlS 
2. Else —> | P:ldle 


This state is entered when an Unknown FIS is received and the CRC for that FIS is correct. When this 
state is entered, PXSERR.DIAG.F has already been set to ‘1’. Note that PXSERR.DIAG-F is set to ‘1’ as 
soon as the HBA recognizes that an unknown FIS has been received. 


5.3.13.2 UFIS:SetlS 


UFIS:SetlS HBA sets IS.IPS[x] bit. 


1. _GHC.IE bit set |__| UFIS:GenIntr 


This state is entered to set status bits in the global interrupt status register. 
§.3.13.3  UFIS:GentIntr 


UFIS:GenIntr HBA generates an interrupt. 


1__Uneondiional Fg 


NOTE: 


The interrupt shall remain set until software completes the appropriate actions to clear it as outlined in 
section 10.6. 


This state is entered to generate an interrupt for the port. See section 10.6 for information on how an 
HBA generates an interrupt. 


5.3.14 BIST States 
5.3.14.1 BIST:FarEndLoopback 


BIST:FarEndLoopback HBA sets PxSSTS.DET to 4h. 
1. _ Unconditional BIST:TestOngoing 


This state is entered when a BIST Activate FIS with far-end loopback mode enabled is received from the 
device. 


5.3.14.2 BIST:TestOngoing 
BIST: TestOngoing 


1. _ Unconditional BIST: TestOngoing 


This state is entered when a BIST Activate FIS is sent by the HBA to the device or received from the 
device. In this state, testing is performed that is outside the scope of this specification. 


Software exits the HBA from this state by clearing PXCMD.ST to ‘0’. 
5.3.15 Error States 
5.3.15.1 ERR:SyncEscapeRecv 

ERR:SyncEscapeRecv 


HBA performs the following actions in the order specified: 
1. Clears both PXTFD.STS.BSY and PxTFD.STS.DRQ to ‘0’. 
2. Sets PxIS.IFS to ‘1’. 
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1. _ Unconditional ERR:Fatal 


This state is entered when a SYNC escape is received for an H2D Register FIS or an H2D Data FIS. 
When a SYNC escape is received, the HBA shall not retransmit the FIS in accordance with Serial ATA 
1.0a. In order to enable timely recovery without a COMRESET, the PxTFD.STS.BSY bit is cleared to ‘0’ 
and PxIS.IFS is set to ‘1’. The HBA shall not clear any of the PxCl bits to ensure that software can 
determine the command that failed. 


5.3.15.2 ERR:Fatal 


This state is entered when the HBA has encountered a condition it cannot recover from. Appropriate 
error bits shall be set by the HBA, and interrupts may optionally be generated. See section 6 for fatal 
conditions. When a fatal condition occurs, the HBA requires PxCMD.ST to be cleared in order to recover. 


The HBA may clear PxCMD.CR to ‘0’ when a fatal error occurs prior to software clearing PXCMD.ST to 
‘0’. The HBA is required to clear PXCMD.CR to ‘0’ after PXCMD.ST is cleared to ‘0’. 


5.3.15.3  ERR:Non-Fatal 


This state is entered when the HBA has encountered an error it can recover from. Appropriate error bits 
shall be set by the HBA, and interrupts may optionally be generated. See section 6 for non-fatal 
conditions. When a non-fatal condition occurs, the HBA shall return to P:ldle after processing the error. 


5.4 HBA Rules (Normative) 
5.4.1. PRD Byte Count Updates 


Each command has a PRD byte count field that is initialized to ‘0’ by software prior to starting a transfer, 
and is updated by hardware as transfers occur. The purpose of this field is to let software know how 
many bytes transferred for a given operation in order to determine if underflow occurred. 


For non-native queued commands, the PRD byte count field shall contain an accurate count of the 
number of bytes transferred for the command before the PxCl bit is cleared to ‘0’ for the command. The 
byte count shall only reflect transmitted data that an R_OK has been received for and received data that 
has a valid CRC. Hardware may update the byte count after each Data FIS is transferred if desired. 


The field should not be used and is not required to be valid when issuing native command queuing 
commands; in this case underflow is always illegal. 


If an overflow occurs, the byte count is not required to reflect the total number of bytes transferred. The 
PxIS.OFS bit should be used to detect overflow. 


5.4.1.1 Data FIS Odd Word Transfers 


If the final Data FIS transfer in a command is for an odd number of 16-bit words, the transmitter’s 
Transport layer is responsible for padding the final Dword of a FIS with zeros. If the HBA receives one 
more word than is indicated in the PRD table due to this padding requirement, the HBA shall not signal 
this as an overflow condition. In addition, if the HBA inserts padding as required in a FIS it is transmitting, 
an overflow error shall not be indicated. The PRD Byte Count field shall be updated based on the 
number of words specified in the PRD table, ignoring any additional padding. 


5.4.2. PRD Interrupt 


When a PRD entry is exhausted, the HBA may be told to generate an interrupt via the ‘I’ bit in the PRD 
entry. Note, though, that a PRD is not considered exhausted until all Data FlSes that transfer data that is 
pointed to by that PRD entry is complete. 


For example, if the Data FIS is 8 KB, and this is covered by 3 PRD entries, the data is not considered 
valid at the end of the first or second PRD, since CRC has not yet been checked, even though the data 
has been copied to memory or the device. Therefore, if the ‘I’ bit is set in the PRD entry, the HBA must 
hold onto it internally and not set PxIS.DPS until the Data FIS is complete and CRC is correct. Once 
correct, PxIS.DPS can be set, and if PxIE.DPE and GHC.IE are set, the HBA shall generate an interrupt. 
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Conversely, if the PRD entry is 16 KB and two 8 KB Data FlSes are used to transfer all of the data 
pointed to by the PRD entry, then the PRD interrupt associated with that PRD entry shall not be signaled 
until after the second Data FIS transfer has completed successfully. 


The PRD Interrupt is an opportunistic interrupt. The PRD Interrupt should not be used to definitively 
indicate the end of a transfer. Two PRD interrupts could happen close in time together such that the 
second interrupt is missed when the first PRD interrupt is being cleared. 


5.5 System Software Rules (Normative) 
5.5.1. Basic Steps when Building a Command 


When software builds a command for the HBA to execute, it first finds an empty command slot by reading 
the PxCl and PxSACT registers for the port. An empty command slot has its respective bit cleared to ‘0’ 
in both the PxCl and PxSACT registers. After a free slot (slot pFreeSlot), is found: 


1. Software builds a command FIS_ in system memory” at __ location 
PxCLB[CH(pFreeSlot)]:CFIS with the command type. 
2. If itis an ATAPI command, the ACMD field shall be filled in with the ATAPI command 
3. Software builds a command header at PxCLB[CH(pFreeSlot)] with: 
a. PRDTL containing the number of entries in the PRD table 
b. CFL set to the length of the command in the CFIS area 
c. Abit set if it is an ATAPI command 
d. W (Write) bit set if data is going to the device 
e. P (Prefetch) bit optionally set (see rules in section 5.5.2) 
f. Ifa Port Multiplier is attached, the PMP field set to the correct Port Multiplier port. 


4. If it is a queued command, software shall first set PXSACT.DS(pFreeSlot). Software 
should only write new bits to set to ‘1’; the previous register content of PXSACT should 
not be re-written in the register write. 

5. Software shall set PxCl.Cl(pFreeSlot) to indicate to the HBA that a command is active. 
Software should only write new bits to set to ‘1’; the previous register content of PxCl 
should not be re-written in the register write. 


5.5.2 Setting CH(pFreeSlot).P 


When software builds commands for the HBA to execute, it may optionally set CH(pFreeSlot).P to enable 
prefetching of PRDs and data. The HBA is not required to prefetch, but may use this bit to do so. To 
avoid potential problems where the HBA may prefetch items it cannot use, software must obey the 
following rules: 


e Software shall not set CH(pFreeSlot).P when building queued ATA commands. The Serial 
ATA device may run the commands in a different order than what is sent. 


e Software shall not set CH(pFreeSlot).P when building commands to several devices behind a 
Port Multiplier when FIS based switching is enabled. FlSes may be received from a Port 
Multiplier for a different device than what was just sent by the HBA. 


If software does not obey these rules, indeterminate HBA behavior may result. 
5.5.3. Processing Completed Commands 


Software processes the interrupt generated by the device for command completion. In the interrupt 
service routine, software checks IS.IPS to determine which ports have an interrupt pending. 


For each port that has an interrupt pending: 

1. Software determines the cause of the interrupt by reading the PxIS register. It is 
possible for multiple bits to be set 

2. Software clears appropriate bits in the PxlS register corresponding to the cause of 
the interrupt. 

3. Software clears the interrupt bit in IS.IPS corresponding to the port. 

4. If executing non-queued commands, software reads the PxCl register, and compares 
the current value to the list of commands previously issued by software that are still 


59 


Revision 1_1.doc Serial ATA AHCI 1.1 Specification 


outstanding. If executing native queued commands, software reads the PxSACT 
register and compares the current value to the list of commands previously issued by 
software. Software completes with success any outstanding command whose 
corresponding bit has been cleared in the respective register. PxCl and PxSACT are 
volatile registers; software should only use their values to determine commands that 
have completed, not to determine which commands have previously been issued. 

5. If there were errors, noted in the PxIS register, software performs error recovery 
actions (see section 6.2.2). 


5.6 Transfer Examples (Informative) 


In all the following examples, it is assumed that PxCMD.ST has been set, and the HBA is only waiting for 
a command to be placed in the command list. If PxCMD.ST is not set, software must do so at some 
point. Additionally, software must ensure that the device has not changed connection status since the 
last command was added by checking PxIS.PCS. 


At any point, the Serial ATA link may be in a Partial or Slumber interface power management state. The 
HBA shall ensure that the link is active before transmitting a FIS on the Serial ATA link (refer to section 
8.3.1.3). 


5.6.1. Macro States 


In the following examples, the HBA traverses a series of states in the port state machine when performing 
data transfers. To simplify the text in the examples, state sequences that are repeated are abbreviated 
here in what are called macro-states. Each of these macro-states assumes no errors were encountered. 


Macro State HBA State Machine States 
Exam:Fetch P:Idle — P:SelectCmd — P:FetchCmd — P:lIdle 
Exam:Transmit P:ldle — CFIS:Xmit — CFIS:Success — P:lIdle 


Exam:AcceptNonData — P:Idle — NDR:Entry > NDR:Accept 
Exam:DMAReceive DR:Entry — DR:Receive — DR:UpdateByteCount — P:Idle 
Exam:DMATransmit DX:Entry > DX:Transmit — DX:UpdateByteCount — P:Idle 
PIO:Entry — DX:Entry — DX:Transmit — DX:UpdateByteCount — 
Exam:PlOTransmit PIO:Update — PIO:ClearCl — PIO:Setintr — PIO:SetIS — PIO:GenIntr — 
PM:Aggr 
DR:Entry — DR:Receive — DR:UpdateByteCount — PIO:Update — 
PIO:ClearCl — PIO:Setintr — PIO:SetlS — PIO:GenIntr — PM:Aggr 
RegFIS:Entry — RegFIS:ClearCl — RegFIS:Setlntr — RegFIS:SetlS — 
RegFIS:GenIntr — RegFIS:UpdateSig — PM:Aggr 
RegFIS:Entry — RegFIS:ClearCl — RegFIS:UpdateSig — 
PM:Aggr 
DmaSet:Entry — DmaSet:Setintr — DmaSet:SetIS — DmaSet:GenIntr = 
DmaSet:AutoActivate 


Exam:PlOReceive 
Exam:D2HIntr 
Exam:D2HNoIntr 


Exam:DMASetup 


5.6.2 DMA Data Transfers 
5.6.2.1. ATADMA Write 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is not 
ATAPI, and is not queued. It is a DMA write (data to device), therefore CH(pFreeSlot).W (Write) shall be 
set to ‘1’, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in section 
5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set to ‘1’, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchPRD — 
CFIS:PrefetchData — P:Idle. 


As this was a DMA write command, the response from the device shall be a DMA Activate FIS. When 
this arrives, the HBA shall accept the FIS by traversing the Exam:AcceptNonData macro state, and shall 
send a Data FIS by traversing the Exam:DMATransmit macro state. 
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If the Data FIS did not satisfy the transfer count, another DMA Activate FIS shall be sent from the device, 
and the HBA shall traverse the Exam:AcceptNonData and Exam:DMATransmit macro states again to 
send another Data FIS. This process continues until the transfer count is satisfied. When the Data FIS 
that completes the transfer count finishes, the next FIS from the device shall be a D2H Register FIS. 


The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register 
FIS had the ‘I’ bit set to ‘1’, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘l’ bit was not set 
to ‘1’, the HBA shall traverse the Exam:D2HNolIntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.2.2. ATAPI Packet DMA Write 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is 
ATAPI, and is not queued. It is a DMA write (data to device), therefore CH(pFreeSlot).W (Write) shall be 
set to ‘1’, and CH(pFreeSlot).P (Prefetch) may optionally be set per the rules described in section 5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchACMD — 
CFIS:PrefetchPRD — CFIS:PrefetchData — P:lIdle. 


Since this was an ATAPI command, the next FIS from the device shall be a PlIO Setup FIS. The HBA 
traverses the Exam:AcceptNonData macro state to accept this FIS, and then traverses the following 
states to transfer the ACMD field to the device: PlO:Entry — ATAPI:Entry — PIO:Update — P:lIdle 


As this command results in a DMA write, the response from the device shall be a DMA Activate FIS. 
When this arrives, the HBA shall accept the FIS by traversing the Exam:AcceptNonData macro state, 
and shall send a Data FIS by traversing the Exam:DMATransmit macro state. 


If the Data FIS did not satisfy the transfer count, another DMA Activate FIS shall be sent from the device, 
and the HBA shall traverse the Exam:AcceptNonData and Exam:DMATransmit macro states again to 
send another Data FIS. This process continues until the transfer count is satisfied. When the Data FIS 
that completes the transfer count finishes, the next FIS from the device shall be a D2H Register FIS. 


The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register 
FIS had the ‘I’ bit set to ‘1’, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘l’ bit was not set 
to ‘1’, the HBA shall traverse the Exam:D2HNolIntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.2.3 ATA DMA Read 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is not 
ATAPI, and is not queued. It is a DMA read (data to memory), therefore CH(pFreeSlot).W (Write) shall be 
cleared to ‘0’, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in 
section 5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set to ‘1’, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchPRD — P:Idle 


As this was a DMA read command, the response from the device shall be a Data FIS. When this arrives, 
the HBA shall traverse the Exam:DMAReceive macro state. 


If the Data FIS did not satisfy the transfer count, another Data FIS shall be sent from the device, and the 
HBA shall traverse the Exam:DMAReceive macro states again. This process continues until the transfer 
count is satisfied. When the Data FIS that completes the transfer count finishes, the next FIS from the 
device shall be a D2H Register FIS. 
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The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register 
FIS had the ‘I’ bit set to ‘1’, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘I’ bit was not set 
to ‘1’, the HBA shall traverse the Exam:D2HNolntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.2.4 ATAPI Packet DMA Read 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is not 
ATAPI, and is not queued. It is a DMA read (data to memory), therefore CH(pFreeSlot).W (Write) shall be 
cleared to ‘0’, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in 
section 5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set to ‘1’, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchACMD — 
CFIS:PrefetchPRD — P:ldle. 


Since this was an ATAPI command, the next FIS from the device shall be a PIO Setup FIS. The HBA 
traverses the Exam:AcceptNonData macro state to accept this FIS, and then traverses the following 
states to transfer the ACMD field to the device: PlO:Entry — ATAPI:Entry — PIO:Update — P:Idle. 


As this command results in a DMA read, the response from the device shall be a Data FIS. When this 
arrives, the HBA shall traverse the Exam:DMAReceive macro state. 


If the Data FIS did not satisfy the transfer count, another Data FIS shall be sent from the device, and the 
HBA shall traverse the Exam:DMAReceive macro states again. This process continues until the transfer 
count is satisfied. When the Data FIS that completes the transfer count finishes, the next FIS from the 
device shall be a D2H Register FIS. 


The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register 
FIS had the ‘I’ bit set to ‘1’, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘l’ bit was not set 
to ‘1’, the HBA shall traverse the Exam:D2HNolIntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.3 PIO Data Transfers 


The following sections describe data transfers to and from a device using PIO as the command protocol 
type. PIO data transfers are highly discouraged because of the inadequate error handling coverage for 
PIO read commands. Some AHCI implementations may choose to only implement support to transfer a 
single DRQ block in a PIO command. If CAP.PMD is cleared to ‘0’, then the HBA only supports single 
DRQ block PIO transfers and software must ensure commands are not issued to the device that are for 
more than one DRQ block of data. Note that when CAP.PMD is cleared to ‘0’, drive functionality is 
reduced. It is recommended that implementations support multiple DRQ block PIO operation. 


Software should ensure that for ATA devices the SET MULTIPLE MODE count is set to a value that is 
less than or equal to 16. Software should ensure that for ATAPI devices, the maximum byte count is set 
to 8KB for the PACKET command. This is required by Serial ATA to ensure that Data FlSes are no larger 
than 8KB. 


From the HBA’s point of view, PIO data transfers look like a DMA transfer. A command table is set up, 
and the data is bus mastered from or to system memory by the HBA. 


5.6.3.1. ATA PIO Write 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is not 
ATAPI, and is not queued. It is a PIO Write (data to device), therefore CH(pFreeSlot).W (Write) shall be 
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set to ‘1’, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in section 
5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchPRD — 
CFIS:PrefetchData — P:Idle. 


As this was a PIO write command, the response from the device shall be a PIO Setup FIS. When this 
arrives, the HBA shall accept the FIS by traversing the Exam:AcceptNonData macro state. It shall then 
traverse the Exam:PlOTransmit macro state to send a Data FIS. 


Since this was PIO write command, the device shall next send a D2H Register FIS. The HBA shall 
accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register FIS had the ‘I’ 
bit set to ‘1’, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘I’ bit was not set to ‘1’, the 
HBA shall traverse the Exam:D2HNolIntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.3.2 ATAPI Packet PIO Write 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is 
ATAPI, and is not queued. It is a PIO Write (data to device), therefore CH(pFreeSlot).W (Write) shall be 
set to ‘1, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in section 
5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set to ‘1’, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchACMD — 
CFIS:PrefetchPRD — CFIS:PrefetchData — P:Idle. 


Since this was an ATAPI command, the next FIS from the device shall be a PlO Setup FIS. The HBA 
traverses the Exam:AcceptNonData macro state to accept this FIS, and then traverses the following 
states to transfer the ACMD field to the device: PlO:Entry — ATAPI:Entry — PIO:Update — P:Idle 


As this was a PIO Write command, the response from the device shall be a PIO Setup FIS. When this 
arrives, the HBA shall accept the FIS by traversing the Exam:AcceptNonData macro state. It shall then 
traverse the Exam:PIOTransmit macro state to send a Data FIS to the device. 


Since this was an PIO ATAPI write command, the device shall send a D2H Register FIS. The HBA shall 
accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register FIS had the ‘I’ 
bit set to ‘1’, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘I’ bit was not set to ‘1’, the 
HBA shall traverse the Exam:D2HNolIntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.3.3 ATA PIO Read 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is not 
ATAPI, and is not queued. It is a PIO Read (data to memory), therefore CH(pFreeSlot).W (Write) shall be 
cleared to ‘0’, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in 
section 5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(plssueTag).P was set to ‘1’, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchPRD — P:Idle 
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As this was a PIO read command, the response from the device shall be a PIO Setup FIS. When this 
arrives, the HBA shall accept the FIS by traversing the Exam:AcceptNonData macro state. It shall then 
traverse the states PIO:Entry — P:Idle, and await a Data FIS from the device. 


When the Data FIS arrives, the HBA traverses the Exam:PlOReceive macro state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.3.4 ATAPI Packet PIO Read 


Software builds a command as described in section 5.5.1. The command shall have a PRD table, is 
ATAPI, and is not queued. It is a PIO Read (data to memory), therefore CH(pFreeSlot).W (Write) shall be 
cleared to ‘0’, and CH(pFreeSlot).P (Prefetch) may optionally be set to ‘1’ per the rules described in 
section 5.5.2. 


The HBA shall transfer the command to the device traversing the macro states Exam:Fetch and 
Exam:Transmit. If CH(IlssueTag).P was set to ‘1’, the HBA shall execute the following states after 
CFIS:Success in the Exam:Transmit macro state before returning to idle: CFIS:PrefetchACMD — 
CFIS:PrefetchPRD — P:Idle. 


Since this was an ATAPI command, the next FIS from the device shall be a PlO Setup FIS. The HBA 
traverses the Exam:AcceptNonData macro state to accept this FIS, and then traverses the following 
states to transfer the ACMD field to the device: PlO:Entry — ATAPI:Entry — PIO:Update — P:Idle 


As this was a PIO read command, the response from the device shall be a PIO Setup FIS. When this 
arrives, the HBA shall accept the FIS by traversing the Exam:AcceptNonData macro state. It shall then 
traverse the states PIO:Entry — H:ldle, and await a Data FIS from the device. 


When the Data FIS arrives, the HBA traverses the Exam:PlOReceive macro state. 


Since this was an ATAPI command, the device shall next send a D2H Register FIS. The HBA shall 
accept this FIS by traversing the Exam:AcceptNonData macro state. If the D2H Register FIS had the ‘I’ 
bit set, the HBA shall traverse the Exam:D2HIntr macro state. If the ‘I’ bit was not set, the HBA shall 
traverse the Exam:D2HNolIntr state. 


If this was the last command, and the HBA was enabled for aggressive power management, the HBA 
shall first request the link to be placed in either the Partial or Slumber interface power management state 
after the PM:Aggr state. 


5.6.4 Native Queued Command Transfers 
5.6.4.1. Introduction 


The ATA/ATAPI-7 queued feature set is not supported by AHCI (including the READ QUEUED (EXT), 
WRITE QUEUED (EXT), and SERVICE commands). Queued operations are supported in AHCI using 
the READ FPDMA QUEUED and WRITE FPDMA QUEUED commands when the HBA and device 
support native command queuing. 


To allow a simple mechanism for the HBA to map command list slots to queue entries, software must 
match the tag number it uses to the slot it is placing the command in. For example, if a queued command 
is placed in slot 5, the tag for that command must be 5. 


System software must determine the maximum tag allowed by the device and the HBA and it must use 
the lower bound of the two. For example, if the HBA has 8 entries in its command list, and the SATA 
device only has 4, only tags 0 — 3 in the device may be used, and only command list entries 0 — 3 may be 
used in the HBA. 


Data transfers are activated with the flow described below via the DMA Setup FIS, and command 
completion is performed via the Set Device Bits FIS. 
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5.6.4.2 Example 


In the following example, the following occurs: 
e System software places 4 commands in system memory: 
o Slot 0 contains a READ FPDMA QUEUED 
o Slot 2 contains a WRITE FPDMA QUEUED 
o Slot 5 contains a READ FPDMA QUEUED 
o Slot 8 contains a WRITE FPDMA QUEUED 
e The HBA fetches the first 3 commands, transfers them to the device, and receives a 
successful completion. 
e Before the HBA can send the 4" command to the device, the device sends a DMA Setup FIS 
to transfer data for the command in slot 2. 
A data transfer occurs to slot 2. 
The HBA transfers slot 8 to the device. 
A data transfer occurs to slot 5. 
The device sends an SDB FIS to clear slots 2 and 5. 
A data transfer occurs to slot 8. 
The device sends an SDB FIS to clear slot 8. 
A data transfer occurs to slot 0. 
The device sends an SDB FIS to clear slot 0. 


Other items to note in this data flow: 
e In both WRITE FPDMA QUEUED commands, the auto-activate bit is not set in the FIS. 
e Every SDB FIS received has the ‘I’ bit set to ‘1’. 


Following is a text description for the flow. 


System Software Places 4 Commands in System Memory 


Software builds a command into slot 0 as described in section 5.5.1. The command shall have a 
PRD table, is not ATAPI, and has a READ FPDMA QUEUED opcode. CH(0).W (Write) shall be 
cleared to ‘0’, and CH(0).P (Prefetch) shall be cleared to ‘0’. 


Software builds a command into slot 2 as described in section 5.5.1. The command shall have a 
PRD table, is not ATAPI, and has a WRITE FPDMA QUEUED opcode. CH(2).W (Write) shall be set 
to ‘1’ and CH(2).P (Prefetch) shall be cleared to ‘0’. 


Software builds a command into slot 5 as described in section 5.5.1. The command shall have a 
PRD table, is not ATAPI, and has a READ FPDMA QUEUED opcode. Both CH(5).W (Write) and 
CH(5).P (Prefetch) shall be cleared to ‘0’. 


Software builds a command into slot 8 as described in section 5.5.1. The command shall have a 
PRD table, is not ATAPI, and has a WRITE FPDMA QUEUED opcode. CH(8).W (Write) shall be set 
to ‘1’, and CH(8).P (Prefetch) shall be cleared to ‘0’. 


At this point, the PxCl and PxSACT register values are “O0000125h” (bits 0, 2, 5, and 8 are set). 
The HBA transmits the First 3 Commands to the Device 


The HBA shall transfer the command from slot 0 to the device traversing the macro states 
Exam:Fetch and Exam:Transmit. As this was a native queued command, the next FIS from the 
device shall be a D2H Register FIS with the ‘I’ bit cleared to ‘0’. 


The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. The ‘I’ bit was 
cleared to ‘0’ so the HBA shall traverse the Exam:D2HNolntr state. PxCl is now equal to 
“00000124h”. 


The HBA shall transfer the command from slot 2 to the device traversing the macro states 
Exam:Fetch and Exam:Transmit. As this was a native queued command, the next FIS from the 
device shall be a D2H Register FIS with the ‘I’ bit cleared to ‘0’. 
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The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. The ‘I’ bit was 
cleared to ‘0’ so the HBA shall traverse the Exam:D2HNolntr state. PxCl is now equal to 
“00000120h”. 


The HBA shall transfer the command from slot 5 to the device traversing the macro states 
Exam:Fetch and Exam:Transmit. As this was a native queued command, the next FIS from the 
device shall be a D2H Register FIS with the ‘I’ bit cleared to ‘0’. 


The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. The ‘I’ bit was 
cleared to ‘0’ so the HBA shall traverse the Exam:D2HNolntr state. PxCl is now equal to 
“00000100h”. 


DMA Setup FIS Arrives for slot 2 


The HBA is now in an idle state, but before it can fetch a new command, a short FIS arrives from the 
device. This FIS is the DMA Setup FIS. The HBA shall accept this FIS by traversing the 
Exam:AcceptNonData macro state, and then traverses the Exam:DMASetup macro state to 
process the DMA Setup FIS. The tag indicated in the FIS was for slot 2. 


Data Transfer for slot 2 


As this was a DMA write command, and the auto-activate bit was not set in the FIS, the next FIS from 
the device shall be a DMA Activate FIS. When this arrives, the HBA shall accept the FIS by 
traversing the Exam:AcceptNonData macro state, and shall send a Data FIS by traversing the 
Exam:DMATransmit macro state. 


If the Data FIS did not satisfy the transfer count, another DMA Activate FIS shall be sent from the 
device, and the HBA shall traverse the Exam:AcceptNonData and Exam:DMATransmit macro 
states again to send another Data FIS. This process continues until the transfer count is satisfied. 
The state machine is now in P:Idle 


HBA transfers slot 8 to the device 


Since PxCl is not all Oh, and no other FIS is coming in from the device, the HBA shall transfer the 
command from slot 8 to the device traversing the macro states Exam:Fetch and Exam:Transmit. 
As this was a native queued command, the next FIS from the device shall be a D2H Register FIS with 
the ‘I’ bit cleared to ‘0’. 


The HBA shall accept this FIS by traversing the Exam:AcceptNonData macro state. The ‘I’ bit was 
cleared to ‘0’ so the HBA shall traverse the Exam:D2HNolntr state. PxCl is now equal to 
“00000000h”. 


Data transfer to slot 5 


A short FIS arrives from the device of type DMA Setup FIS. The HBA shall accept this FIS by 
traversing the Exam:AcceptNonData macro state, and then traverses the Exam:DMASetup macro 
state to process the DMA Setup FIS. The tag indicated in the FIS was for slot 5. 


As this was a DMA read command, the next FIS from the device shall be a Data FIS. When this 
arrives, the HBA shall traverse the Exam:DMAReceive macro state. 


If the Data FIS did not satisfy the transfer count, another Data FIS shall be sent from the device, and 
the HBA shall traverse the Exam:DMAReceive macro states again. This process continues until the 
transfer count is satisfied. The HBA state machine is now in P:Idle. 


Device sends SDB FIS to clear slots 2 and 5 


At this point, the device sends an SDB FIS to indicate slots 2 and 5 are complete. The HBA shall 
accept this FIS by traversing the Exam:AcceptNonData macro state, and then traverses the 
SDB:Entry, and, since the received FIS had the ‘I’ bit set, the SDB:SetIntr — SDB:SetlIS — 
SDB:Genlntr states, and returns to PM:Aggr — P:ldle. The PxSACT register is now equal to 
“00000101h”. 


Data transfer occurs to slot 8 
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A short FIS arrives from the device of type DMA Setup FIS. The HBA shall accept this FIS by 
traversing the Exam:AcceptNonData macro state, and then traverses the Exam:DMASetup macro 
state to process the DMA Setup FIS. The tag indicated in the FIS was for slot 8. 


As this was a DMA write command, and the auto-activate bit was not set in the FIS, the next FIS from 
the device shall be a DMA Activate FIS. When this arrives, the HBA shall accept the FIS by 
traversing the Exam:AcceptNonData macro state, and shall send a Data FIS by traversing the 
Exam:DMATransmit macro state. 


If the Data FIS did not satisfy the transfer count, another DMA Activate FIS shall be sent from the 
device, and the HBA shall traverse the Exam:AcceptNonData and Exam:DMATransmit macro 
states again to send another Data FIS. This process continues until the transfer count is satisfied. 
The HBA state machine is now in P:Idle. 


Device sends SDB FIS to clear slot 8 


At this point, the device sends an SDB FIS to indicate slot 8 is complete. The HBA shall accept this 
FIS by traversing the Exam:AcceptNonData macro state, and then traverses the SDB:Entry, and, 
since the received FIS had the ‘I’ bit set, the SDB:SetIntr — SDB:SetIS — SDB:GenlIntr states, and 
returns to PM:Aggr — P:Idle. The PxSACT register is now equal to “O0000001h”. 


Data transfer occurs to slot 0 


A short FIS arrives from the device of type DMA Setup FIS. The HBA shall accept this FIS by 
traversing the Exam:AcceptNonData macro state, and then traverses the Exam:DMASetup macro 
state to process the DMA Setup FIS. The tag indicated in the FIS was for slot 2. 


As this was a DMA read command, the next FIS from the device shall be a Data FIS. When this 
arrives, the HBA shall traverse the Exam:DMAReceive macro state. 


If the Data FIS did not satisfy the transfer count, another Data FIS shall be sent from the device, and 
the HBA shall traverse the Exam:DMAReceive macro states again. This process continues until the 
transfer count is satisfied. The HBA state machine is now in P:Idle. 


Device sends SDB FIS to clear slot 0 


At this point, the device sends an SDB FIS to indicate slot 0 is complete. The HBA shall accept this 
FIS by traversing the Exam:AcceptNonData macro state, and then traverses the SDB:Entry, and, 
since the received FIS had its | bit set, the SDB:SetIntr — SDB:SetIS — SDB:Genlntr states, and 
returns to PM:Aggr. The PxSACT register is now equal to “OO000000h’. 


Since the PxCl and PxSACT registers are now both equal to “OO000000h”, if the HBA was enabled 
for aggressive power management, the HBA shall first request the link to be placed in either the 
Partial or Slumber power management after the PM:Aggr state. 
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6 Error Reporting and Recovery 


All errors within an HBA occur within ports. There are no errors that apply to the entire host controller. 
There are several sources of errors that could occur during a transfer. Examples of errors are: 

e System Memory — Bad system memory pointers cause data fetches and stores to be lost 

e Interface / Device - such as CRC problems, illegal state machine transitions, etc. 


6.1. Error Types 
6.1.1. System Memory Errors 


System memory errors such as target abort, master abort, and parity may cause the host to stop 
processing the currently running command. These are serious errors that cannot be recovered from 
without software intervention (section 6.2.2). 


A master/target abort error occurs when system software has given a pointer to the HBA that does not 
exist in physical memory. When this occurs, the HBA aborts the transfer (if necessary) as described in 
section 6.2.1. When this is complete, the HBA sets PxIS.HBFS. If PxIE.HBFE and GHC.IE are set, the 
HBA shall also generate an interrupt. . 


A data error (such as CRC or parity), may or may not be transient. If the error occurred on a fetch of a 
CFIS, PRD entry or command list, the HBA shall stop. If the error occurred on a data FIS or the ACMD 
field, the HBA is allowed to stop, but may also continue. When a data error occurs, the HBA aborts the 
transfer (if necessary) as described in section 6.2.1. When this is complete, the HBA sets PxIS.HBDS. If 
PxIE.HBDE and GHC.IE are set, the HBA shall also generate an interrupt. 


If the HBA continue after a data error on a data or ACMD field, it shall poison the CRC of the Data FIS it 
transfers to the device. 


6.1.2 Interface Errors 


Interface errors are errors that occur due to electrical issues on the interface, or protocol 
miscommunication between the device and HBA. Depending on the type of error, different bits in the 
PxSERR register are set. When these bits are set, either PxIS.IFS (fatal) or PxIS.INFS (non-fatal) shall 
be set, and if enabled, the HBA shall generate an interrupt. 


Conditions that cause PxIS.IFS/PxIS.INFS to be set are: 
e Inthe PxSERR.ERR field, the P bit is set to ‘1’ 
e Inthe PxSERR.DIAG field, the C or H bit is set to ‘1’ 
e PhyRdy drops unexpectedly 


Examples of these types of errors are below, with the corresponding PxSERR bit that is set if appropriate. 


The only difference between PxIS.IFS and PxIS.INFS being set is the type of FIS that is being 
transmitted/received when the error occurs. If the error occurred during a non-Data FIS, the FIS must be 
retransmitted, so the error is non-fatal and PxIS.INFS is set. If the error occurred during a Data FIS, the 
transfer shall stop, so the error is fatal and PxIS.IFS is set. 


In the case of a non-Data FIS error, between seeing a non-Data FIS fail and the attempt to re-transmit, 
the HBA may receive other FlSes from the device (this will most likely happen when performing native 
command queuing commands). When this occurs, the HBA must accept the FIS, perform the correct 
actions, and then retry the failed FIS. 


If the HBA was transmitting a Data FIS it does not retry the FIS and waits for software to clear the 
PxCMD.ST bit to ‘0’. The HBA shall retransmit a non-Data FIS continuously after a failure until either the 
transfer succeeds or system software stops the controller by clearing PXCMD.ST to ‘0’. 


e Received Disparity Error / Illegal Character (K28.3): When a disparity error is encountered, the 
HBA assumes the disparity of this character is correct and resets the running disparity counter in 
the 8b/10b decoder. No error bits are set. 

e Received Disparity Error / Illegal Character (D): When this occurs, the HBA returns R_ERR at 
the end of the FIS. It sets PXSERR.DIAG.B. Note that PxIS.IFS/PxIS.INFS shall not be set; the 
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CRC error that is likely to occur due to this event will set the appropriate bit. If there is an illegal 
character outside the FIS boundaries, the HBA may ignore the event and is not required to set 
PxSERR.DIAG.B. 

e PhyRdy Dropping Unexpectedly: When this occurs, the HBA returns to idle. If the PhyRdy 
signal dropped during the middle of a command, the HBA may have to be restarted. If the 
PhyRdy signal dropped outside of a FIS, neither the PxIS.IFS nor the PxIS.INFS bits shall be set. 

e Calculated Different CRC than Received: When this occurs, the HBA returns R_ERR and 
returns to idle. It sets PXSERR.DIAG.C 

e Incorrect FIS or FIS with Illegal Length for Corresponding FIS Type Received: When this 
occurs, the HBA returns R_ERR at end of the FIS, shall not post the FIS to memory, and returns 
to idle. It sets PxSERR.ERR.P. This can only be done for supported FIS types. An unknown FIS 
is not considered an illegal FIS, unless the length received is more than 64 bytes. If an unknown 
FIS arrives with length <= 64 bytes, it is posted and the HBA continues normal operation. 

e =©Internal Buffer Overflow: This occurs when the HBA sends a HOLD, but a HOLDA was not 
received quickly enough by the HBA, and the HBA’s internal data FIFOs overflow. The HBA 
returns R_ERR at the end of the FIS. It sets PXSERR.ERR.P. 

e HBA Receives R_ERR: If the HBA receives an R_ERR to a FIS it was transmitting, it sets 
PxSERR.DIAG.H. 

e IS received from a device, where both BSY and DRQ are to be updated in the Status 
register and both PxTFD.STS.BSY and PxTFD.STS.DRQ are cleared: When this occurs, the 
HBA returns R_OK, does not set any error bits, and does not update any registers or the received 
FIS area based on the received FIS (i.e. the FIS is ignored). No error bits are set because this is 
a valid occurrence when enumerating devices on a Port Multiplier. 


It is system software’s responsibility to check the PxSERR register periodically to determine if the 
interface is operating cleanly, and take appropriate actions (such as going down to Generation’ speed if 
operating at a higher speed or notifying the user) when interface errors occur. 


Note that when an error such as a bad CRC or an illegal length occurs, the HBA cannot trust the 
incoming FIS to be correct. For example, the HBA may have thought the FIS was a D2H Register FIS, 
but if the CRC is incorrect, it could be because the type specified in the FIS is incorrect. 


To address this problem, the HBA shall not update its internal registers, nor update the FIS received area, 
until it determines that a non-Data FIS it received was valid. If the HBA believes the FIS to be a Data FIS, 
however, it may copy it to memory at the appropriate PRD location. This is because Data FlSes may be 
as long as 8KB. An HBA may set other error or diagnostic bits based on the FIS contents when there is a 
CRC error; these bits may not be completely accurate due to the CRC error. It is possible that a fatal 
error is generated due to a non-fatal CRC error. In this case, software should perform the normal 
procedure to recover from a fatal error. 


6.1.3. Port Multiplier Errors 


When a Port Multiplier is connected, if a FIS is received from a device, where the PMP field does not 
match what is expected, the HBA returns R_OK and sets PxIS.IPMS. The HBA shall discard the packet 
and not update any registers or memory structures based on the FIS contents. In command-based 
switching, this indicates that the only active PMP port was not properly returned. In FIS based switching, 
this indicates that a PMP field was returned that is not in the list of active PMPs. 


6.1.4 Device Errors 


When a FIS arrives that updates the taskfile, the HBA checks to see if PxTFD.STS.ERR is set. If it is, 
and PxlE.TFEE is set, the HBA shall generate an interrupt and stop processing any more commands. 


6.1.5 Command List Overflow 


Command list overflow is defined as software building a command table that has fewer total bytes than 
the transaction given to the device. On device writes, the HBA will run out of data, and on reads, there 
will be no room to put the data. 
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For an overflow on data read, either PIO or DMA, the HBA shall set PxIS.OFS, and if enabled via 
PxIE.OFE and GHC.IE, generate an interrupt. When this condition occurs on data reads, the HBA shall 
make a best effort to continue, however the HBA may not be able to recover without software 
intervention. Overflow is a serious error, thus software should perform a fatal error recovery procedure to 
ensure that the HBA is brought back to a known condition before continuing. For an overflow on writes, 
the HBA may transmit HOLDs to the device since it does not have any data to satisfy the request size; a 
COMRESET is required by software to clean up from this serious error. For an overflow on data writes 
with DMA, the HBA does not know there is more data until it receives the next DMA Activate. When this 
occurs, it may optionally set PxIS.OFS and attempt to terminate the transfer. However, this is a fatal 
condition, and an HBA is allowed to hang on the transfer. For PIO writes, the HBA receives the PIO 
Setup FIS and therefore knows the length, and therefore may optionally set PxIS.OFS. However, by not 
satisfying the length, the transfer shall end in an error, and software must recover. Therefore setting 
PxIS.OFS is optional for both DMA and PIO data write conditions. Detecting overflow and setting 
PxIS.OFS on native command queuing commands is optional. 


6.1.6 Command List Underflow 


Command list underflow is defined as software building a command table that has more total bytes than 
the transaction given to the device. 


For data writes, both PIO and DMA, the device shall detect an error and end the transfer. These errors 
are most likely going to be fatal errors that will cause the port to be restarted. For data reads, the HBA 
shall update its PRD byte count with the total number of bytes received from the last FIS, and may be 
able to continue normally, but is not required to. 


The HBA is not required to detect underflow conditions for native command queuing commands. 
6.1.7 Native Command Queuing Tag Errors 


The HBA does not actively check incoming DMA Setup FlSes to ensure that the PxSACT register bit for 
that slot is set. 


The reason for this is if the device gives an incorrect tag, it could just as likely be for a tag that is active. 
In this case, the HBA would see no error, although the data transfer that occurs is incorrect. Therefore, 
there is little benefit in the HBA checking for inactive tags. Just as in the wrong active tag case, the data 
transfer that occurs will be incorrect. 


Existing error mechanisms, such as host bus failure, or bad protocol, are used to recover from this case. 
6.1.8 PIO Data Transfer Errors 


In accordance with Serial ATA 1.0a, Data FlSes prior to the final Data FIS must be an integral number of 
Dwords. If the HBA receives an intermediate Data FIS transfer request that is not an integral number of 
Dwords, the HBA shall set PXSERR.ERR.P to ‘1’, set PxIS.IFS to ‘1’ and stop running until software 
restarts the port. 


The HBA shall ensure that the size of the Data FIS received during a PlO command matches the size in 
the Transfer Count field of the preceding PIO Setup FIS. If the Data FIS size does not match the Transfer 
Count field in the preceding PIO Setup, the HBA shall respond with R_ERR to the Data FIS, set 
PxSERR.ERR.P to ‘1’, set PxIS.IFS to ‘1’, and then stop running until software restarts the port. 


6.2 Error Recovery 
6.2.1. HBA Aborting a Transfer 


When the HBA detects an error that it cannot recover from, it may need to end the transfer on the SATA 
interface. 


To do this, the HBA asserts SYNC Escape to stop the bad FIS, and when the device is quiescent, returns 
to idle. The SATA device should send a D2H Register FIS at this point, with the ERR bit set to indicate 
an error in the transfer. 
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When aborting a transfer, the HBA does not wait for the D2H Register FIS before proceeding with error 
recovery (such as setting interrupt status bits and generating interrupts). This is because a device may 
be in a hung condition and cannot generate the D2H Register FIS. 


6.2.2 Software Error Recovery 


When an interrupt is generated due to an error condition, software will attempt to recover. Fatal errors 
(signified by the setting of PxIS.HBFS, PxIS.HBDS, PxIS.IFS, or PxIS.TFES) will cause the HBA to enter 
the ERR:Fatal state, and clear PXCMD.CR. In this state, the HBA shall not issue any new commands nor 
acknowledge DMA Setup FlSes to process any native command queuing commands. To recover, the 
port must be restarted; the port is restarted by clearing PXCMD.ST to ‘0’ and then setting PxCMD.ST to 
‘1’. For non-fatal errors (signified by the setting of PxIS.INFS or PxIS.OFS) the HBA continues to operate. 


If the transfer was aborted (see section 6.2.1), the device is expected to send a D2H Register FIS with 
PxTFD.STS.ERR set to ‘1’ and both PxTFD.STS.BSY and PxTFD.STS.DRQ cleared to ‘0’. Under this 
scenario, system software knows that the device is in a stable state and transfers may be restarted 
without issuing a COMRESET to the device. 


For fatal errors, software must determine which commands were not processed and either re-issue them 
or notify higher level software that the command failed. The steps involved are listed in the following 
sections. 


To detect an error that requires software recovery actions to be performed, software should check 
whether any of the following status bits are set on an interrupt: PxIS.HBFS, PxlIS.HBDS, PxIS.IFS, and 
PxIS.TFES. If any of these bits are set, software should perform the appropriate error recovery actions 
based on whether non-queued commands were being issued or native command queuing commands 
were being issued. 


6.2.2.1 Non-Queued Error Recovery 


The flow for system software to recover from an error when non-queued commands are issued is as 
follows: 
e Reads PxCl to see which commands are still outstanding 
e Reads PxCMD.CCS to determine the slot that the HBA was processing when the error 
occurred 
Clears PxCMD.ST to ‘0’ to reset the PxCl register, waits for PXCMD.CR to clear to ‘0’ 
Clears any error bits in PXSERR to enable capturing new errors. 
Clears status bits in PxIS as appropriate 
If PXTFD.STS.BSY or PXTFD.STS.DRQ is set to ‘1’, issue a COMRESET to the device to put 
it in an idle state 
e Sets PxCMD.ST to ‘1’ to enable issuing new commands 
e Optionally issue a command to gather information about the error, for example READ LOG 
EXT, if software did not have to perform a reset (COMRESET or software reset) as part of 
the error recovery. 


Software then either completes the command that had the error and commands still outstanding with 
error to higher level software, or re-issues these commands to the device. 


6.2.2.2 Native Command Queuing Error Recovery 


The flow for system software to recover from an error when native command queuing commands are 
issued is as follows: 
e Reads PxSACT to see which commands have not yet completed 
e Clears PxCMD.ST to ‘0’ to reset the PxCl and PxSACT registers, waits for PXCMD.CR to 
clear to ‘0’ 
e Clears any error bits in PXSERR to enable capturing new errors. 
e Clears status bits in PxIS as appropriate 
e If PxXTFD.STS.BSY or PxTFD.STS.DR@Q is set to ‘1’, issue a COMRESET to the device to put 
it in an idle state 
e Sets PXCMD.ST to ‘1’ to enable issuing new commands 
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e Issue READ LOG EXT to determine the cause of the error condition if software did not have 
to perform a reset (COMRESET or software reset) as part of the error recovery 


Software then either completes commands that did not finish with error to higher level software, or re- 
issues them to the device. 


6.2.2.3. Recovery of Unsolicited COMINIT 


An unsolicited COMINIT is a COMINIT that is not received as a consequence of issuing a COMRESET to 
the device (refer to Serial ATA II: Extensions to Serial ATA 1.0a revision 1.2). If the HBA receives an 
unsolicited COMINIT during normal operation, the HBA shall perform the following actions: 

e Respond to the device with a COMRESET 

e Halt execution until PxIS.PCS is cleared to ‘0’ by software 


To detect this condition, software should check whether PxIS.PCS is set to ‘1’ on an interrupt. The HBA 
cannot guarantee that a device received a COMRESET because a COMINIT may appear to be solicited 
to the HBA if it happens to occur closely to an issued COMRESET. Therefore, when software detects 
that PxIS.PCS is set, software should first issue a COMRESET to ensure that the device receives a 
COMRESET. Then software should perform the appropriate actions to clear PxIS.PCS to ‘0’. To recover, 
software should perform error recovery actions for a fatal error condition (including restarting the 
controller). Then software should perform a re-enumeration to check whether a new device has been 
inserted. 
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7 Hot Plug Operation 
7.1. Platforms that Support Cold Presence Detect 


For platforms that support cold-presence detect, additional logic is required on the board that implements 
the SATA ports. How this logic is implemented is beyond the scope of this specification. 


7.1.1. Device Hot Unplugged 


When a powered-down device is removed, the HBA shall be notified through an external pin. The HBA 
set PxIS.CPDS to indicate the device changed state. If PxIE.;CPDE and GHC.IE are set, the HBA shall 
also generate an interrupt. Software should then check PxCMD.CPS to determine whether a device is 
present. 


7.1.2 Device Hot Plugged 


When a device is added, the HBA shall be notified through an external pin. The HBA shall report that the 
device status changed by setting PxIS.CPDS to indicate the device changed state. If PxIE.;CPDE and 
GHC.IE are set, the HBA shall also generate an interrupt. Software should then check PxCMD.CPS to 
determine whether a device is present. 


7.2. Platforms that Support Mechanical Presence Switches. 


For platforms that support mechanical presence switches, additional logic is required on the board that 
implements the SATA ports. How this logic is implemented is beyond the scope of this specification. The 
net result of the logic, though, is that whenever the logic changes state, a high logic level will be sent to 
the HBA, which shall set PxIS.DMPS. 


Setting of this bit in and of itself does not imply a hot plug or unplug event, but is a notification to software 
that the device state may have changed. 


7.3. Native Hot Plug Support 


The HBA must support native hot plug. Hot plug insertion is detected by reception of a COMINIT signal 
from the device. Hot plug removal is detected by a change in the state of the HBA’s internal PhyRdy 
signal. 


On reception of an unsolicited COMINIT, the HBA shall generate a COMRESET. If the COMINIT is in 
response to a COMRESET, then the HBA shall begin the normal communication negotiation sequence as 
outlined in the Serial ATA 1.0a specification. When a COMRESET is sent to the device the PxSSTS.DET 
field shall be cleared to Oh. When a COMINIT is received, the PxSSTS.DET field shall be set to ‘1h. 
When the communication negotiation sequence is complete and PhyRdy is true the PxSSTS.DET field 
shall be set to 3h. 


The HBA shall set the PxSERR.DIAG.X bit to ‘17 when a COMINIT is received from the device. Hot plug 
insertions are detected via the PxIS.PCS bit that directly reflects the PXSERR.DIAG.X bit. The HBA shall 
set the PxSERR.DIAG.N bit to ‘1’ when the HBA’s internal PhyRdy signal changes state. Hot plug 
removals are detected via the PxIS.PRCS bit that directly reflects the PxSERR.DIAG.N bit. Note that 
PxSERR.DIAG.N is also set to ‘1’ on insertions and during interface power management entry/exit. 


When PhyRdy transitions from ‘1’ to ‘0’, the HBA may update PxSSTS.DET to 1h since the reason for the 
loss of communications is not fully known. 


7.3.1. Hot Plug Removal Detection and Power Management Interaction (Informative) 


PhyRdy changes state when a device is inserted, when a device is disconnected, and when the link 
enters/exits a Partial or Slumber interface power management state. Thus, if interface power 
management is enabled for a port, the PXSERR.DIAG.N bit may be set due to the link entering the Partial 
or Slumber power management state, rather than due to a hot plug insertion or removal event. 


To reliably get removal detection notification via the PXSERR.DIAG.N bit, interface power management 
must be disabled for the port. When the Serial ATA link is in a Partial or Slumber interface power 
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management state, device removals cannot be detected and reported via the PxSERR.DIAG.N bit 
because there is no active signal on the link. 


7.3.1.1 Software Flow for Hot Plug Removal Detection (Informative) 


To reliably detect hot plug removals, software must disable interface power management. Software 
should perform the following initialization on a port after a device is attached: 


Set PxSCTL.IPM to 3h to disable interface power management state transitions. 

Set PxCMD.ALPE to ‘0’ to disable aggressive power management. 

Ensure PxlE.PRCE is set to ‘1’ to enable interrupts on hot plug removals. 

Disable device initiated interface power management by issuing the appropriate SET FEATURES 
command. 


During normal operation, software should check PxlS.PRCS to determine if a hot plug removal has 
occurred. 


7.3.1.2 Software Flow for Power Management (Informative) 


To utilize power management on a port and avoid spurious interrupts due to PhyRdy transitions, software 
should disable the interrupt for hot plug removal. Software should perform the following initialization on a 
port after a device is attached: 


e Clear PxIE.PRCE to ‘0’ to disable interrupts on PhyRdy state changes. 
e Set PxSCTL.IPM to Oh to enable interface power management state transitions. 
e Set PxCMD.ALPE and PxCMD.ASP appropriately based on the aggressive power management 
policy. 
During normal operation, software should check that PXSSTS.DET is set to 3h to ensure that a hot plug 
removal has not occurred. 


7.4 Interaction of the Command List and Port Change Status 


Software may have one or several commands in the command list at the time a device is unplugged. A 
new device may also be inserted before software has had an opportunity to see the change. 


When a hot plug event occurs, software will normally stop outstanding commands to the device that was 
removed and begin issuing commands to the new device. To accomplish this, an HBA shall stop 
transferring data, return to an idle condition, and clear PxCMD.CR whenever PxIS.PCS is set. This 
allows software to see what commands are outstanding by checking PxCl, PxSACT, and PxCMD.CCS. 
Once software has determined which commands need to be re-issued, it shall clear PXCMD.ST and 
restart the controller by setting PxCMD.ST and taking any necessary actions to enable the SATA device. 


74 


Serial ATA AHCI 1.1 Specification Revision 1_1.doc 


8 Power Management Operation 
8.1. Introduction 


This section covers power management of the HBA and the Serial ATA interface. This specification does 
not cover any power management that a Serial ATA device may do internally that is transparent to the 
interface. 


8.2 Power State Mappings 


The PCI specification defines power management states for devices, which shall be applied to the HBA. 
They are: 
e DO- Working (required) 
e D1-—Not defined for storage HBAs 
e D2-—-Not defined for storage HBAs 
e D3 -Very deep sleep (required). This state is split into two sub-states, D3yo07 (can respond 
to PCI configuration accesses) and D3co.p (cannot respond to PCI configuration accesses). 
These two sub-states are considered the same, where D307 has Vcc, but D3co.p does not. 
PxCMD.ST must be cleared to ‘0’ before entering the D3 power state. 


Serial ATA devices may also have multiple power states. Each of these device states are subsets of the 
HBA’s DO state. They are: 
e DO - Device is working and instantly available. 
e D1 -— Device enters when it receives an IDLE IMMEDIATE command. Exit latency from this 
state is in seconds. 
e D2 —- Device enters when it receives a STANDBY (IMMEDIATE) command. Exit latency 
from this state is in seconds. 
e D3 - Device enters when it receives a SLEEP command. Exit latency from this state is in 
seconds. 


Finally, Serial ATA defines three Phy layer (or interface) power states. They are: 
e Phy Ready — Phy logic and PLL are both on and active 
e Partial — Phy logic is powered, but in a reduced state. Exit latency is no longer than 10us 
e Slumber — Phy logic is powered, but in a reduced state. Exit latency can be up to 10ms. 


Since these states have much lower exit latency than the D1, D2, and D3 states, AHCI defines these 
states as sub-states of the device DO state. 


The following picture gives a hierarchical view of power states of Serial ATA. 


Figure 18: Power State Hierarchy 


Device = DO 


PHY = PHY = PHY = 
Ready Partial (Che 


Resume Latency 


Note: The Phy is not required to be in a Slumber state when the device is in a D1, D2 or D3 state, nor is it 
required to be in a Slumber state when the HBA is in a D3 state. While this may be the likely condition of 
the interface when the devices connected to the interface are in a low power state, it is not a requirement, 
and the interface shall break out of these states on a power management event. 
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8.3 Power State Transitions 
8.3.1 Interface Power Management 


The Serial ATA 1.0a specification defines two lower power interface power management states, Partial 
and Slumber, in order to save power on the Serial ATA link in power sensitive systems. The Partial and 
Slumber interface power management states can be initiated by software, the HBA itself, or by the 
device. The interface power management state is negotiated between the host and the device on the 
interface using Serial ATA primitives. Any request can be accepted (using the PMACK primitive) or 
rejected (using PMNACK primitives) based upon current conditions and settings in the device and HBA. 
The current interface power management state is reflected to software in PxSSTS.IPM. 


8.3.1.1 Device Initiated 


By default, a device that supports initiating interface power management states has the capability 
disabled. To enable this feature, the appropriate SET FEATURES command may be issued to the 
device. The HBA shall respond to device initiated power management requests as specified by 
PxSCTL.IPM. A request from the device to enter an interface power management state may be rejected 
by the HBA if the HBA needs to transmit a FIS to the device. 


8.3.1.2 System Software Initiated 


PxCMD.ICC is used by system software to initiate interface power management state transitions. The 
request to transition to a different interface power management state shall only be acted on by the HBA if 
the Link layer is currently in the L_IDLE state. If the HBA’s Link layer is not in the L_IDLE state when the 
PxCMD.ICC field is written, the request shall be ignored. The HBA shall not perform a transition directly 
from Partial to Slumber or from Slumber to Partial based on a new value being written to PXCMD.ICC. If 
the link is currently in a Partial or Slumber interface power management state, it is software’s 
responsibility to bring the link to the active state before requesting a transition to a different interface 
power management state. The time from the request written to PxCMD.ICC until the link is active is 
bounded by the maximum recovery times from Partial or Slumber as outlined in the Serial ATA 1.0a 
specification. 


8.3.1.3 HBA Initiated 


The HBA may implement aggressive power management, as indicated in CAP.SALP. Aggressive power 
management allows the HBA to initiate an interface power management state as soon as there are no 
commands outstanding to the device. This enables immediate entry into the low power interface state 
without waiting for software in power sensitive systems. The PxCMD.ALPE bit defines whether the 
feature is enabled and the PxCMD.ASP field controls whether Partial or Slumber is initiated by the HBA 
when enabled. 


When PxCMD.ALPE is set to ‘1’, if the HBA recognizes that there are no commands to process, the HBA 
shall initiate a transition to Partial or Slumber interface power management state based upon the setting 
of PXCMD.ASP. The HBA recognizes no commands to transmit as either: 
e PxSACT is set to Oh, and the HBA updates PxCl from a non-zero value to Oh. 
e PXxCl is set to Oh, and a Set Device Bits FIS is received that updates PxSACT from a non- 
zero value to Oh. 


If the PxSACT and PxCl registers are both cleared to Oh, and the interface is in an active state, the HBA 
shall not initiate placing the interface into a lower power state, unless PXCMD.ICC is written with an 
appropriate value. 


Before performing a FIS transmission, the HBA must ensure the link is in the active state. If the link is in 
the Partial or Slumber interface power management state, a COMWAKE must be issued, and the HBA 
must wait until the link is active before proceeding with transmission of the FIS. 


8.3.1.4 Software Requirements and Precedence 


Software must check CAP.SSC (Slumber capable) and CAP.PSC (Partial capable) to determine if the 
HBA supports interface power management transitions as an initiator or a target. If an interface power 
management state is not supported, then software shall not write the PxCMD.ICC field nor set the 
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aggressive power management capability to initiate a transition to that state. Software must set the 
PxSCTL.IPM field to disable transition to any unsupported interface power management state. If 
CAP.SSC or CAP.PSC is cleared to ‘0’, software should disable device-initiated power management by 
issuing the appropriate SET FEATURES command to the device. 


The Serial ATA 1.0a specification defines the proper behavior of the link layer when a host initiated and 
device initiated power state transition occur concurrently. HBA initiated interface power management 
requests are higher priority than software initiated requests. Thus if the HBA and software request 
transitions to different states at the same time, the HBA’s request shall take precedence over the software 
request. 


8.3.2 Device D1, D2, and D3 States 


The D1, D2, and D3 device states are entered when system software has determined that no commands 
will be sent to the device for some time. To enter these states, software may perform two actions. The 
first is to issue a command to the device to enter the low power state (IDLE IMMEDIATE for D1, 
STANDBY (IMMEDIATE) for D2, SLEEP for D3), and the second step is to put the interface into a 
Slumber power management state (by setting PxCMD.ICC to 6h). 


Note: It is recommended that the device initiate a Slumber power management state when it receives a 
command to enter the D1, D2, or D3 state. 


8.3.3 HBA D3 state 


After the interface and device have been put into a low power state, the HBA may be put into a low power 
state. This is performed via the PCI power management registers in configuration space. AHCI only 
supports the DO and D3 device power states. 


As per the PCI Power Management Specification version 1.2, the two D3 states defined are D3hot and 
D3cold. The defining difference between these two states is the absence (D3cold) or presence (D3hot) of 
Vcc. The two DO states defined are DOunitialized and D0Oinitialized. Functions in D3hot can be 
transitioned to the DO state via software by writing to the function’s PMCSR register. Functions in the 
D3cold state can only be transitioned to a DOuninitialized state by reapplying Vcc and asserting Bus 
Segment Reset (RST#) to the HBA. Functions in the D3hot state can be transitioned to the 
DOuninitialized state or the D0Oinitialized state; device’s designed to the PCI Bus Power Management 
Interface Specification Revision 1.2 are allowed to support either D3hot->DOinitialized or D3hot — 
DOuninitialized transitions. PCl Bus Power Management Interface Specification Revision 1.1 does not 
have this flexibility - only D3hot/cold — DOuninitialized is supported. 


There are several important aspects to note when using PCI power management. 

e When the power state is D3, only accesses to configuration space are allowed. Any attempt to 
access the register memory space must result in master abort. 

e When the power state is D3, no interrupts may be generated, even if they are enabled. If an 
interrupt status bit is pending when the controller transitions to DO, an interrupt may be 
generated. 

e When the HBA transitions from D3cold to DO, system software (BIOS and/or device specific 
drivers) is required to restore all registers needed to place the HBA in a usable state. This is 
required since a D3cold (Vcc removed) to DO will place the HBA in an uninitialized state. 
Typically, if the system BIOS participates in the resume path (i.e. resume from system standby, 
hibernate, power-on, etc) where the HBA is placed in a D3cold state, then the BIOS will be 
expected to restore/program registers residing in the HBA’s PCI configuration space (for PCI add- 
in cards, this is limited to bytes 00 — 63 in PCI configuration space) as well as those registers in 
the HBA’s memory mapped IO space that are specified as “Implementation Specific” (not 
applicable for PCI add-in cards). For those registers not restored/programmed by the BIOS during 
D3cold — DO transitions (i.e. bytes 64 — 255 in PCI configuration space, HBA implementation 
specific, etc) it is the device specific OS driver’s responsibility to restore the HBA to a working 
(DOinitialized) state. 

e When the HBA transitions from D3hot to DOinitialized, no specific re-initialization by the system 
BIOS or device is required 
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e When the HBA transitions from D3hot to DOunitialized, then re-initialization of the device is 
performed exclusively by the device specific OS driver(s) — no system BIOS assistance is 
required. 


Software must disable interrupts (GHC.IE must be cleared to ‘0’) prior to requesting a transition of the 
HBA to the D3 state. This precaution by software avoids an interrupt storm if an interrupt occurs during 
the transition to the D3 state. 


PxCMD.ST must be cleared to ‘0’ before entry into the D3 power state. 
8.4 PME 
When the HBA is in the D3 state, it may optionally wake based on a change in the device state. 


PME must be generated when the HBA is in the D3 state under the following conditions: 
e PxIS.PCS is set to ‘1’ due to a native hot plug insertion 
e PxlS.DMPS set, indicating a mechanical presence switch has been opened or closed 
e PxIS.CPDS set, indicating cold presence detect state change 
e Set Device Bits FIS received on the interface with the ‘I’ bit set to ‘17. The HBA may 
require that the Notification (‘N’) bit also be set to ‘1’ in the Set Device Bits FIS; this is 
implementation specific. 


If any of these bits are set, regardless of the setting of the enables in PxIE and GHC.IE, the HBA shall 
generate PME#. 
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9 Port Multiplier Support 


Port Multiplier support for HBAs is optional, and its support is indicated to system software via CAP.SPM. 
If Port Multipliers are supported in the HBA, it must support command-based switching. This section 
describes the hardware and software differences necessary to make a Port Multiplier work. 


9.1 Command Based Switching 


In this mode of operation, a communication path is opened between the HBA and a device through the 
Port Multiplier. Since Port Multipliers are meant to be simple, the burden of making a connection is on 
AHCI software, to ensure that multiple commands are not outstanding to different devices behind the Port 
Multiplier. 


9.1.1 Non-Queued Operation 


When running non-queued commands, the command list may be filled with any combination of ports, and 
each command list entry can target a different port. There is no fixed relationship between number of 
commands allocated to the device and the number of devices behind a Port Multiplier. For example, 29 
commands could be allocated to the device behind PM port #0,and 3 commands for the remaining 
devices, if that is desired by system software. 


Since the commands are non-queued, the HBA shall execute each command entry in its entirety before 
moving to the next entry in the command list, which may include a command to a different port. 


This places special burden on system software for building commands. Since the HBA operates in order 
in its command list, system software should not fill the list in sequential order with commands to a single 
device; otherwise another device may get starved. Take the following example: 
e 4devices attached to a PM behind a port 
e The operating system presents several commands 
o 4to the device behind PM port #0 
o 2 to the device behind PM port #1 
o 1 to the device behind PM port #2 


If the AHCI software placed these commands in sequential order, starting at command slot 0, the list 
would look as follows: 
e Slot #0: PM Port #0, Command 1 
Slot #1: PM Port #0, Command 2 
Slot #2: PM Port #0, Command 3 
Slot #3: PM Port #0, Command 4 
Slot #4: PM Port #1, Command 1 
Slot #5: PM Port #1, Command 2 
Slot #6: PM Port #2, Command 1 


This would cause the device behind port #2 to not execute its command for a very long time. In the worst 
case scenario, 31 commands to other devices behind different PM ports may execute before this 
command is allowed to execute. 


A better placement of commands to result in fairer execution would be as follows: 
e Slot #0: PM Port #0, Command 1 

Slot #1: PM Port #1, Command 1 

Slot #2: PM Port #2, Command 1 

Slot #8: PM Port #0, Command 2 

Slot #9: PM Port #1, Command 2 

Slot #16: PM Port #0, Command 3 

Slot #24: PM Port #0, Command 4 


Mapping commands in this fashion helps ensure that the device behind PM port #2 has a fairer chance of 
executing. The above algorithm results in round-robin execution of commands. Many algorithms for 
fairness exist, and their implementations are beyond the scope of this specification. 
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In order to find the best slot for placing the next command, software should use PxCMD.CCS to find the 
current slot the HBA is executing, and place the command in an appropriate slot for the fairness algorithm 
that is desired. 


9.1.2 Queued Operation 


Since queued commands result in two different operations (command issue, clear of BSY, then data 
transfer), if commands were sent to different ports, the Port Multiplier may issue FlSes back to the HBA in 
an interleaved manner from different ports. This will break an HBA that only supports command-based 
switching. Therefore, when executing native command queuing commands, system software must only 
add commands to the command list that target a single port behind the Port Multiplier, wait for the 
commands to finish (PXSACT bits all cleared), then add commands for a different port. Additionally, the 
tags used must match the command slot entries. 


9.2. Port Multiplier Enumeration 


In order to enumerate a Port Multiplier, a software reset is issued to port OFh (control port) on the Port 
Multiplier. If the signature returned corresponds to a Port Multiplier, then a Port Multiplier is attached. If 
the signature returned corresponds to another device type, then a Port Multiplier is not attached. 


To reliably enumerate the Port Multiplier, regardless of the presence of a device on Port Multiplier device 
port 0, the PXCMD.CLO (command list override) bit should be used if this feature is supported by the HBA 
(indicated by CAP.SCLO being set to ‘1’). Software should ensure that the PxCMD.ST bit is ‘0’. Then 
software should construct the two Register FlSes required for a software reset in the command list, where 
the PM Port field value in the Register FIS is set to OFh. After constructing the FlSes in the command list, 
software should set PxCMD.CLO to ‘1’ to force the BSY and DRQ bits in the Status register to be cleared. 
Then software should set the PxCMD.ST bit to ‘1’ and set appropriate PxCl bits in order to begin 
execution of the software reset command. 


If the CAP.SCLO bit is cleared to ‘0’, a Port Multiplier can only be enumerated after a device on Port 
Multiplier device port 0 sends a Register FIS to the host that clears PxTFD.STS.BSY and 
PxTFD.STS.DRQ to ‘0’. 


9.3 FIS-based Switching 


To be defined in a future AHCI specification. 
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10 Platform Communication 
10.1 Software Initialization of HBA 


Before any useful work can be performed, the HBA must be initialized. Initialization consists of two 
independent phases: a firmware phase (platform BIOS) and a system software phase. Initialization of the 
HBA’s PCI configuration space is beyond the scope of this specification. 


10.1.1 Firmware Specific Initialization 


To aid system software during runtime, the BIOS shall ensure that the following registers are initialized to 
values that are reflective of the capabilities supported by the platform. Firmware shall always initialize the 
following registers and values: 

e CAP.SSS (support for staggered spin-up) 

e CAP.SMPS (support for mechanical presence switches) 

e PI (ports implemented) 

e PxCMD.HPCP (whether port is hot plug capable). Firmware shall initialize the HPCP bit for each 
port implemented on the platform (as defined by the PI register). The PxCMD.HPCP should be 
set to ‘1’ if PXCMD.MPSP or PxCMD.CPD is set to ‘1’ for the port. 

e PxCMD.MPSP (whether mechanical presence switch is attached to the port). Firmware shall 
initialize the MPSP bit for each port implemented on the platform (as defined by the PI register). 

e PxCMD.CPD (whether cold presence detect logic is attached to the port). Firmware shall 
initialize the CPD bit for each port implemented on the platform (as defined by the PI register). 


After firmware has initialized the aforementioned registers, it shall then perform the following steps to 
complete the staggered spin-up process (if applicable to the platform) on each port implemented by the 
AHCI HBA (as indicated by the PI register): 


Indicate that system software is AHCI aware by setting GHC.AE to ‘1’. 


2. Ensure that PXCMD.ST = ‘0’, PXCMD.CR = ‘0’, PXCMD.FRE = ‘0’, PXCMD.FR = ‘0’, and 
PxSCTL.DET = ‘Oh’. 

3. Allocate memory for the command list and the FIS receive area. Set PxCLB and 
PxCLBU to the physical address of the allocated command list. Set PXxFB and PxFBU to 
the physical address of the allocated FIS receive area. Then set PxCMD.FRE to ‘1’. 

4. Initiate a spin up of the SATA drive attached to the port; i.e. set PXCMD.SUD to ‘1’. 

5. Wait for a positive indication that a device is attached to the port (the maximum amount 

of time to wait for presence indication is specified in the Serial ATA 1.0a specification). 

This is done by polling PXSSTS.DET. If PXxSSTS.DET returns a value of 1h or 3h when 

read, then system software shall continue to the next step, otherwise if the polling 

process times out system software moves to the next implemented port and returns to 

step 1. 

Clear the PXSERR register, by writing ‘1s’ to each implemented bit location. 

Wait for indication that SATA drive is ready. This is determined via an examination of 

PxTFD.STS. If PxTFD.STS.BSY, PxTFD.STS.DRQ, and PxTFD.STS.ERR are all ‘0’, 

prior to the maximum allowed time as specified in the ATA/ATAPI-7 specification, the 

device is ready. 


ao 


10.1.2 System Software Specific Initialization 


This section describes how system software places the AHCI HBA into a minimally initialized state. 
Because the term “system software” is used to collectively reference both the platform BIOS and 
operating system, this section applies to any software that is AHCI aware. Note that some steps may not 
be required for system BIOS (e.g. ensuring that the controller is not running) since the host controller will 
be in a known state following a system reset. Additionally, if system BIOS already allocated memory for 
and initialized the appropriate registers for the command list and FIS receive area, it may skip this step of 
the process. Software may perform an HBA reset prior to initializing the controller by setting GHC.AE to 
‘1’ and then setting GHC.HR to ‘1’ if desired. 
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To place the AHCI HBA into a minimally initialized state, system software shall: 


1. Indicate that system software is AHCI aware by setting GHC.AE to ‘1’. 

2. Determine which ports are implemented by the HBA, by reading the PI register. This bit 
map value will aid software in determining how many ports are available and which port 
registers need to be initialized. 

3. Ensure that the controller is not in the running state by reading and examining each 
implemented port’s PxCMD register. If PxCMD.ST, PxCMD.CR, PxCMD.FRE and 
PxCMD.FR are all cleared, the port is in an idle state. Otherwise, the port is not idle and 
should be placed in the idle state prior to manipulating HBA and port specific registers. 
System software places a port into the idle state by clearing PxCMD.ST and waiting for 
PxCMD.CR to return ‘0’ when read. Software should wait at least 500 milliseconds for 
this to occur. If PXCMD.FRE is set to ‘1’, software should clear it to ‘0’ and wait at least 
500 milliseconds for PxCMD.FR to return ‘0’ when read. If PXCMD.CR or PXCMD.FR do 
not clear to ‘0’ correctly, then software may attempt a port reset or a full HBA reset to 
recover. 

4. Determine how many command slots the HBA supports, by reading CAP.NCS. 

5. For each implemented port, system software shall allocate memory for and program: 

e PxCLB and PxCLBU (if CAP.S64A is set to ‘1’) 
e PxFB and PxFBU (if CAP.S64<A is set to ‘1’) 


It is good practice for system software to ‘zero-out’ the memory allocated and referenced 
by PxCLB and PxFB. After setting PxFB and PxFBU to the physical address of the FIS 
receive area, system software shall set PXCMD.FRE to ‘1’. 

6. For each implemented port, clear the PxSERR register, by writing ‘1s’ to each 
implemented bit location. 

7. Determine which events should cause an interrupt, and set each implemented port’s PxIE 
register with the appropriate enables. To enable the HBA to generate interrupts, system 
software must also set GHC.IE to a ‘1’. 


Note: Due to the multi-tiered nature of the AHCI HBA’s interrupt architecture, system 
software must always ensure that the PxIS (clear this first) and IS.IPS (clear this second) 
registers are cleared to ‘0’ before programming the PxIE and GHC.IE registers. This will 
prevent any residual bits set in these registers from causing an interrupt to be asserted. 


At this point the HBA is in a minimally initialized state. System software may provide additional 
programming of the GHC register and port PxCMD and PxSCTL registers based on the policies of the 
operating system and platform — these details are beyond the scope of this specification. 


Software shall not set PxCMD.ST to ‘1’ until it is determined that a functional device is present on the port 
as determined by PxTFD.STS.BSY = ‘0’, PXTFD.STS.DRQ = ‘0’, and PxSSTS.DET = 3h. Note that to 
enable the PxTFD register to be updated with the initial Register FIS for a port, the PXSERR.DIAG.X bit 
must be cleared to ‘0’. 


10.2 Hardware Prerequisites to Enable/Disable GHC.AE 


When a legacy interface is supported in addition to AHCI (CAP.SAM = ‘0’), software may desire to switch 
from one mode to the other. Actively switching between AHCI and a legacy mode is strongly discouraged 
due to OS sensitivity to the class code used by the controller. This section lists hardware requirements 
only for switching between AHCI mode and a legacy mode, it does not comprehend any software 
considerations. 


To switch from legacy mode to AHCI mode, the legacy interface shall be in an idle state and there should 
be no outstanding commands to any devices connected to the controller. Additionally, any transaction 
errors reported through the legacy task file status register (i.e. ERR == '1') shall be rectified prior to 
switching to AHCI mode. This can be accomplished via a software reset. At this point, software can begin 
the sequence for initializing the AHCI controller outlined in section 10.1. 
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To switch from AHCI mode to legacy mode, the AHCI controller must be brought to an idle state for all 
ports and there should be no outstanding commands to any devices connected to the controller. The 
PxCMD.ST should be cleared to ‘0’ for all ports and software should ensure that the PxCMD.CR bit is 
cleared to ‘0’ for all ports. The PxCMD.FRE bit should be cleared to ‘0’ for all ports and software should 
ensure that PxCMD.FR is cleared to ‘0’ for all ports. Then software should clear the GHC.IE bit to ‘0’ to 
ensure there are no interrupts that occur on the AHCI controller. At this point, software may set the 
GHC.AE bit to ‘0’. Commands may be issued at this point to the legacy controller. 


10.3 Software Manipulation of Port DMA Engines 


Each port contains two major DMA engines. One DMA engine walks through the command list, and is 
controlled by PXCMD.ST. The second DMA engine copies received FlSes into system memory, and is 
controlled by PXCMD.FRE. 


10.3.1 Start (PxCMD.ST) 


When PxCMD.ST is set to ‘1’, software is limited in what actions it is allowed to perform on the port (refer 
to section 5.3.2.3). 
e It shall not manipulate PXCMD.POD to power on or off a device through cold presence detect 
logic (if supported by the HBA). 
e = It shall not manipulate PxSCTL.DET to change the Phy state 
e It shall not manipulate PxCMD.SUD to spin-up the device (if supported by the HBA) 


The above actions are only allowed while the HBA is idle, indicated by both PxCMD.ST and PxCMD.CR 
being equal to ‘0’. This is noted by the HBA state machine H:NotRunning state. If software performs any 
of the above actions while the port is not idle (PxCMD.ST or PxCMD.CR are set to ‘1’), indeterminate 
results may occur. 


Software shall not set PXCMD.ST to ‘1’ until it verifies that PxCMD.CR is ‘0’ and has set PXCMD.FRE to 
‘1’. Additionally, software shall not set PXCMD.ST to ‘1’ until a functional device is present on the port (as 
determined by PxTFD.STS.BSY = ‘0’, PxTFD.STS.DRQ = ‘0’, and PxSSTS.DET = 3h) and 
PxCLB/PxCLBU are programmed to valid values.. 


Before the HBA enters the low power D3 state, software shall clear PXCMD.ST to ‘0’. 
10.3.2 FIS Receive Enable (PxCMD.FRE) 


When PxCMD.FRE is set (causing PXCMD.FR to be set to ‘1’), the HBA receives FlSes from the device 
and copies them into system memory. When PxCMD.FRE is cleared (causing PxCMD.FR to be cleared 
to ‘0’), received FlSes are held internally, and if the HBA’s internal FIFO is full, further FIS reception is 
blocked. 


Software is allowed to manipulate PxCMD.FRE so that it may move the FIS receive area to a new 
location. When this bit is cleared to ‘0’, software must first wait for PXCMD.FR to clear to ‘0’, indicating 
that the DMA engine for FIS reception is in an idle condition. When PxCMD.FR and PxCMD.FRE are 
both cleared to ‘0’, software may update the values of PxFB and PxFBU. Prior to setting PXCMD.FRE to 
‘1’, software shall ensure that PxFB and PxFBU are set to valid values. Software shall not write PxFB 
and PxFBU while PxCMD.FRE is set to ‘1’. 


Software shall set this bit to ‘1’ prior to setting PXCMD.ST to ‘1’. Software shall not clear this bit while 
PxCMD.ST or PxCMD.CR is set to ‘1’. 


Upon HBA reset, this bit is cleared. The D2H register FIS containing the device signature shall be 
accepted by the HBA, and the signature field updated. 


Note that if the HBA stops running due to an error (for example, PxIS.IFS is set to ‘1’), FiSes may not be 
posted until the PxCMD.ST bit is cleared to ‘0’ to recover from the error. 


10.4 Reset 


AHCI supports three levels of reset: 
e Software — a single device on one of the ports is reset, but the HBA and physical communication 
remain intact. This is the least intrusive. 
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e Port — the physical communication between the HBA and device on a port are disabled. This is 
more intrusive 
e HBA - the entire HBA is reset, and all ports are disabled. This is the most intrusive. 


When an HBA or port reset occurs, Phy communication shall be re-established with the device through a 
COMRESET followed by the normal out-of-band communication sequence defined in Serial ATA. At the 
end of the reset, the device, if working properly, will send a D2H Register FIS, which contains the device 
signature. When the HBA receives this FIS, it updates PXTFD.STS and PxTFD.ERR register fields, and 
updates the PxSIG register with the signature. 


Software is recommended to follow a staggered reset approach, starting from a less intrusive reset 
mechanism and then using a more intrusive reset mechanism only if the less intrusive mechanism does 
not succeed in clearing the condition. 


10.4.1 Software Reset 


Legacy software contained a standard mechanism for generating a reset to a Serial ATA device — setting 
the SRST (software reset) bit in the Device Control register. Serial ATA has a more robust mechanism 
called COMRESET, also referred to as port reset. A port reset is the preferred mechanism for error 
recovery and should be used in place of software reset. 


To issue a software reset in AHCI, software builds two H2D Register FlSes in the command list. The first 
Register FIS has the SRST bit set to ‘1’ in the Control field of the Register FIS, the ‘C’ bit is set to ‘0’ in the 
Register FIS, and the command table has the CH[R] (reset) and CH[C] (clear BSY on R_OK) bits set to 
‘1’. The CH[R] (reset) bit causes the HBA to perform a SYNC escape if necessary to put the device into 
an idle condition before sending the software reset. The CH[C] (clear BSY on R_OkK) bit needs to be set 
for the first Register FIS to clear the BSY bit and proceed to issue the next Register FIS since the device 
does not send a response to the first Register FIS in a software reset sequence. The second Register 
FIS has the SRST bit set to ‘0’ in the Control field of the Register FIS, the ‘C’ bit is set to ‘0’ in the Register 
FIS, and the command table has the CH[R] (reset) and CH[C] (clear BSY on R_Ok) bits cleared to ‘0’. 
Refer to the Serial ATA 1.0a specification for more information on the software reset FIS sequence. 


When issuing a software reset sequence, there should not be other commands in the command list. 
Before issuing the software reset, software must clear PXCMD.ST, wait for the port to be idle (PXCMD.CR 
= ‘0’), and then re-set PxCMD.ST. PxTFD.STS.BSY and PxTFD.STS.DRQ must be cleared prior to 
issuing the reset. If PXTFD.STS.BSY or PxTFD.STS.DRQ is still set based on the failed command, then 
a port reset should be attempted or command list override (PXCMD.CLO) should be used if supported. 


10.4.2 Port Reset 


If a port is not functioning properly after a software reset, software may attempt to re-initialize 
communication with the port via a COMRESET. It must first clear PXCMD.ST, and wait for PxCMD.CR to 
clear to ‘0’ before re-initializing communication. However, if PxCMD.CR does not clear within a 
reasonable time (500 milliseconds), it may assume the interface is in a hung condition and may continue 
with issuing the port reset. 


Software causes a port reset (COMRESET) by writing 1h to the PxSCTL.DET field to invoke a 
COMRESET on the interface and start a re-establishment of Phy layer communications. Software shall 
wait at least 1 millisecond before clearing PXSCTL.DET to Oh; this ensures that at least one COMRESET 
signal is sent over the interface. After clearing PxSCTL.DET to Oh, software should wait for 
communication to be re-established as indicated by bit 0 of PXSSTS.DET being set to ‘1’. Then software 
should write all 1s to the PXSERR register to clear any bits that were set as part of the port reset. 


When PxSCTL.DET is set to 1h, the HBA shall reset PXTFD.STS to 7Fh and shall reset PXSSTS.DET to 
Oh. When PxSCTL.DET is set to Oh, upon receiving a COMINIT from the attached device, 
PxTFD.STS.BSY shall be set to 1’ by the HBA. 


10.4.3 HBA Reset 


If the HBA becomes unusable for multiple ports, and a software reset or port reset does not correct the 
problem, software may reset the entire HBA by setting GHC.HR to ‘1’. When software sets the GHC.HR 
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bit to ‘1’, the HBA shall perform an internal reset action. The bit shall be cleared to ‘0’ by the HBA when 
the reset is complete. A software write of ‘0’ to GHC.HR shall have no effect. To perform the HBA reset, 
software sets GHC.HR to ‘1’ and may poll until this bit is read to be ‘0’, at which point software knows that 
the HBA reset has completed. 


If the HBA has not cleared GHC.HR to ‘0’ within 1 second of software setting GHC.HR to ‘1’, the HBA is in 
a hung or locked state. 


When GHC.HR is set to ‘1’, GHC.AE, GHC.IE, the IS register, and all port register fields (except 
PxFB/PxFBU/PxCLB/PxCLBU) that are not Hwinit in the HBA’s register memory space are reset. The 
HBA’s configuration space and all other global registers/bits are not affected by setting GHC.HR to ‘1’. 
Any Hwlnit bits in the port specific registers are not affected by setting GHC.HR to ‘1’. The port specific 
registers PxFB, PxFBU, PxCLB, and PxCLBU are not affected by setting GHC.HR to ‘1’. If the HBA 
supports staggered spin-up, the PxCMD.SUD bit will be reset to ‘0’; software is responsible for setting the 
PxCMD.SUD and PxSCTL.DET fields appropriately such that communication can be established on the 
Serial ATA link. If the HBA does not support staggered spin-up, the HBA reset shall cause a COMRESET 
to be sent on the port. 


10.5 Interface Speed Support 


The HBA indicates the maximum speed it can support via the CAP.ISS register. Software can further limit 
the speed of a port by manipulating each port's PxSCTL.SPD field to a lower value. If software writes a 
value that is greater than the value in CAP.ISS, the actual speed negotiated will be limited by CAP.ISS, 
as shown in the following table: 


CAP.ISS PxSCTL.SPD | Maximum Speed Negotiated 
th Oh 1.5 Gbps 
th th 1.5 Gbps 
th 2h 1.5 Gbps 
2h Oh 3 Gbps 
2h th 1.5 Gbps 
2h 2h 3 Gbps 


If PXSCTL.SPD is set to a non-zero value when system software loads, platform BIOS (or expansion 
ROM) decided that the current port required speed limitation. Speed limitation may be set by the platform 
BIOS to avoid an inordinate number of errors on a port; e.g. a laptop swapbay connector that goes 
through several intermediate connectors may need to speed limitation for robust operation. _ If 
PxSCTL.SPD is set to a non-zero value when system software loads, system software should preserve 
this setting, including across power management state transitions. It is recommended that platform BIOS 
(or expansion ROM) not specify a speed limitation unless it is necessary for robust operation. If system 
software encounters errors and speed could be limited further, system software is allowed to restrict the 
speed negotiated to a slower rate. 


10.6 Interrupts 
10.6.1 Tiered Operation 


AHCI defines a two-tiered interrupt architecture, which allows for reporting of interrupts to software such 
that software can handle interrupts through the least amount of programming and status checking. A 
diagram of the interrupt tiers is shown below: 
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Figure 19: Interrupt Tiers 


MC.MSIE 


MSI Engine 
PCI Pin Engine 


1* tier 


2”¢ tier 


10.6.1.1 First Tier (IS Register) 
The first tier is identified by the GHC and IS registers. 


The GHC.IE bit enables interrupts for the entire HBA. This is the master enable. Until this bit is set, the 
HBA shall not generate any interrupts. When it is cleared, the HBA may set Interrupt Status bits in the IS 
register but no interrupt is asserted on the controller. This bit is only a mask, and does not affect the 
setting of any of the interrupt status bits in any of the ports. These bits are set regardless of whether or 
not interrupts are enabled. 


The 32-bit IS register reports whether a port has an interrupt pending. This is a bit-mapped register 
indicating a bit for each of the 32 ports allowed in AHCI. Each bit location can be thought of as reporting 
a ‘1’ if the virtual “interrupt line” for that port is indicating it wishes to generate an interrupt. That is, if a 
port has one or more interrupt status bit set, and the enables for those status bits are set, then this bit 
shall as set. The bits in this register are read/write clear. It is set by the level of the virtual interrupt line 
being a set, and cleared by a write of ‘1’ from the software. 


This register allows software to perform a quick glance of the HBA to see which ports are reporting 
interrupts. By being read/write clear, it also allows for the implementation of message signaled interrupts. 


10.6.1.2 Second Tier (PxIS Registers) 


The second tier is identified in each port, through the PxIS (status) and PxIE (interrupt enable) registers. 
The PxIS register for each port has various interrupt bits 


Each one of these interrupts can be individually enabled or disabled for a port, by setting the 
corresponding bit in PxIE. The status bit in PxIS is always set regardless of the setting of the 
corresponding PxIE bit. 


10.6.2 HBA/SW Interaction 
10.6.2.1 Pin Based and Single MSI Message Based Behavior 


This is the mode of interrupt operation if any of the following conditions are met: 
e Pin based interrupts are being used — MSI is disabled (MSICAP.MC.MSIE=’0’) 
e Single MSI is being used — MSI is enabled (MSICAP.MC.MSIE='1’) and MSICAP.MC.MME=0h 


In this mode, the IS register determines whether the PCI interrupt line shall be driven active or MSI 
message shall be sent. The PxIS register contains status information to generate the interrupt. The 
resulting logical “AND” of the PxIS bit and corresponding PxIE bit results in a “virtual wire” that sets a 
sticky bit in the IS register. When a level of a virtual wire for a port is ‘1’, the IS register bit for that port 
shall be set. 
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The resulting output of the IS register is sent to one of two places. If MSIs are not enabled, the resulting 
IS bits are logical “ORed” together — any bit being a one causes the PCI interrupt line to be active 
(electrical ‘0’). If MSIs are enabled, any change to the IS register that doesn’t result in the register being 
all cleared shall cause an MSI to be sent. Therefore, that in wire mode, a single wire remains active, 
while in MSI mode, several messages may be sent, as each edge triggered event on a port shall cause a 
new message, as shown in Figure 20. 


In order to clear an interrupt, software must first clear the event from the PxIS register, then clear the 
interrupt event from the IS register. If software clears IS register only, leaving the level of the virtual wire 
from the PxIS register set, the resulting level of ‘1’ shall cause the IS register bit to be re-set. 


Figure 20: MSI vs. PCI IRQ Actions 


Status of Tier 1 Register Wire-Mode Action MSI Action 

All bits ‘0’ Wire inactive No action 

One or more bits set to ‘1’ Wire active New message sent 
One or more bits set to ‘1’, new bit gets set to ‘1’ Wire active New message sent 
One or more bits set to ‘1’, software clears some (but not all) ; : 

bits Wire active New message sent 
One or more bits set to ‘1’, software clears all bits Wire inactive No action 


10.6.2.2 Multiple MSI Based Messages 


An HBA may optionally support multiple MSI messages for better performance. In this mode, multiple 
interrupt messages are allocated for the controller; each port may have its own interrupt message. To 
support this mode, the MSICAP.MC.MMC field represents a power-of-2 wrapper on the number of 
implemented ports in the global memory space PI register. For example, if 3 ports are implemented, then 
the MSICAP.MC.MMC field must be ‘010’ (4 interrupts). 


Multiple-message MSI enables each port to send its own interrupt message, as opposed to a single 
message for all ports. When enabled for multiple message generation, generation of interrupts is no 
longer controlled through the IS register. Hardware shall continue to set the IS register just as in the 
single message case, however the IS register is not used to determine whether to generate an MSI. The 
IS register may be used by software if fewer than the requested number of messages is granted in order 
to determine which port had the interrupt. The GHC.IE register shall still be a global interrupt 
enable/disable for all ports when multiple-message MSI is used. 


Each port receives its own interrupt message, up to a maximum of 16 interrupts (16 ports). 16 interrupts 
is the practical limit of MSI messages in an x86/Windows environment. The mapping of ports to interrupts 
is done in a 1-1 relationship, up to the maximum number of assigned interrupts. 


When generating an MSI message, a port looks at its PxIS register, and uses the following rules to 
generate a message: 
e If a new bit is set in PxIS, and the corresponding bit in PxIE is set, send a message 
e If bits are cleared in PxlS, and other bits remain set, if their corresponding bits in PxIE are set, 
send a message. 
e = If a PxIE bit transitions from ‘0’ to ‘1’ and the corresponding bit in PxIS is set, send a message. 


10.6.2.3 Multiple MSI When Fewer Messages Allocated Than Requested 


When the number of MSI messages allocated is less than the number requested, hardware may 
implement one of two behaviors: 


e Hardware may assign each port its own interrupt and then force all additional ports to share the 
last interrupt message allocated, indicated by clearing GHC.MRSM to ‘0’. 
e Hardware may revert to single MSI mode, indicated by setting GHC.MRSM to ‘1’. 


These two behaviors for are outlined in the following subsections. 
10.6.2.3.1 Sharing Last Message 


When fewer MSI messages are allocated than requested, hardware may assign each port its own 
message until all messages are allocated. Then hardware assigns the last/maximum interrupt message 
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to any unassigned port. Thus, the last/maximum interrupt message is shared amongst several ports. 
Software should use the IS register to determine which port has had an interrupt when the last/maximum 
interrupt message triggers an interrupt. Messages are assigned starting at port 0 and then incremented 
upward. When this mechanism is used, GHC.MRSM shall be cleared to ‘0’. Interrupts are generated 
based on the rules for multiple MSI messages in section 10.6.2.2. 


Take the following example in Figure 20, where 6 ports are implemented (ports 0 — 5) and command 
completion coalescing is supported and uses IS.IPS bit 6. When only 4 messages are allocated 
(messages 0 — 3), the mapping of ports to interrupts is as follows: 


Figure 21: Port/CCC and MSI Message Mapping, Example 1 
IS bit Port # 
or CCC 
Port 0 0 
Port 1 1 
Port 2 2 
Port 3 
Port 4 
Port 5 
CCC 


Interrupt Message 


O]} O01} BR} G/N} =>/O 


When multiple MSI is supported, the HBA shall request at least as many messages as the maximum IS 
bit in use (either the maximum port number or the IS bit that command completion coalescing uses). 
Each implemented port maps to an interrupt message of the same value if enough messages are 
allocated. For example, port 2 maps to message 2, even if port 1 is not implemented. Figure 22 is an 
example, showing 6 ports, where only ports 0, 3, and 5 are implemented. In this example, command 
completion coalescing is not supported. 


Figure 22: Port and MSI Message Mapping, Example 2 
Port Interrupt Message 
0 
1 (unused) 
2 (unused) 
3 
4 (unused) 
5 
6 (unused) 
- 7 (unused) 


1 /ONBILO!N|>/O 


In this example, since the HBA had 6 ports, it is required to ask for 8 interrupt messages. In this example, 
therefore, messages 6 and 7 are also not used. 


If multiple ports share the same MSI message, the rules for generating an MSI must be implemented 
across all the ports that share that message. For example, in example 1 ports 3-7 share a single 
message. If all P4IS bits are cleared, but (P3IS & P3lIE) is non-zero, anew message is sent. 


10.6.2.3.2 Reverting to Single MSI Mode 


The advantage of multiple MSI is often negated when fewer messages are allocated than requested. To 
reduce hardware and software complexity, hardware may choose to revert to single MSI mode when 
fewer messages are allocated than requested. When single MSI mode is reverted to, hardware 
generates interrupts based on the rules for single MSI in section 10.6.2.1. To indicate that hardware has 
reverted to single MSI mode, hardware shall set the GHC.MRSM bit to ‘1’, as described in section 3.1.2. 


10.6.3 Disabling Device Interrupts (NIEN Bit in Device Control Register) 


The NIEN bit was part of the device control register (legacy I/O addresses 3F6h for primary, 376h for 
secondary). A legacy HBA must snoop writes to this bit to know whether to mask device interrupts. An 
AHCI HBA does not snoop this bit. AHCI does not use the NIEN bit; all masking is controlled via the PxIE 
register. Software should always set the NIEN bit to ‘0’ in all Register FlSes transmitted to the device. 
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10.7 Mechanical Presence Switch Operation 


In systems that support a mechanical presence switch, the platform contains a mechanical mechanism 
that acts as an attention indicator or locking mechanism. When this mechanism changes state (such as a 
button pressed or switch opened/closed), a line changes state. This line is a level driven signal, not 
edge-triggered. 


HBAs that support mechanical presence switches have the following additional features: 
e CAP.SMPS shall be set to ‘1’ 
e PxCMD.MPSP shall be set to ‘1’ for each port that has a mechanical presence switch attached. 
e An additional input pin per port on the HBA, the level is reflected in PXCMD.MPSS which shows 
whether the mechanical presence switch is open or closed. 


10.8 Cold Presence Detect Operation 


In systems that support cold presence detect, the platform board contains voltage comparator logic, as 
described in the Serial ATA II specification, for recognizing attachments, and FET control to supply power 
to the device. 


HBAs that support cold presence-detect have the following additional features: 
e PxCMD.CPD shall be set to ‘1’ for each port that has cold presence detection capability. 
e An additional input pin per port on the HBA. 
e An additional output pin per port on the HBA to be used as FET control for the power rails to the 
device. 
e For each port, PXCMD.POD shall be read/write. 


When an HBA that supports cold presence-detect is first powered-up, no power is supplied to the 
devices. Initialization software checks the status of the ports, and if a device is connected, sets 
PxCMD.POD to a ‘1’ to supply power to the port. 


10.9 Staggered Spin-up Operation 


Staggered spin-up is an optional feature in the Serial ATA II: Extensions to Serial ATA 1.0a revision 1.2 
specification. This feature enables an HBA to individually spin-up attached devices. The feature is useful 
to avoid having a power supply that must handle maximum current draw from all devices at the same time 
when applying power to the devices. In order for a system to support staggered spin-up, the devices, the 
HBA, and BlOS/driver must all support staggered spin-up. 


In systems that support staggered spin-up, an HBA can individually spin-up devices connected to 
implemented SATA ports. In systems that do not support staggered spin-up, the HBA spins up all 
connected SATA devices upon receiving power to the HBA. 


Staggered spin-up is only performed when power is applied to the drive. If the drive has been spun-down 
due to an ATA command (e.g. STANDBY) and the device continues to be powered, the drive will not 
spin-up again until access to the media is required — the staggered spin-up mechanism is not invoked in 
this case. Note that when a system transitions to system power management state S3 or greater, the 
drive will cease having power applied. Since the drive loses power, when the drive is powered back on in 
the transition back to SO, the drive will undergo another staggered spin-up process. 


HBAs that support staggered spin-up shall have the following additional features: 
e CAP.SSS shall be set. 
e For each port, PXCMD.SUD shall be read/write. 


10.9.1 Interaction of PXSCTL.DET and PxCMD.SUD 


In systems that support staggered spin-up, there is an interaction between PxSCTL.DET and 
PxCMD.SUD in controlling the Phy behavior. The two register fields must be set correctly in 
order to avoid illegal combinations of the two values. In systems that do not support staggered 
spin-up, PXCMD.SUD is read-only and always set to ‘1’ such that there is no interaction. 
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The PxSCTL.DET value manipulates the behavior of the Phy. For platforms that support staggered spin- 
up, PXCMD.SUD also manipulates the behavior of the Phy. The following table describes the interaction. 


PxSCTL.DET | PxCMD.SUD Mode Behavior 
Interface in a reduced power state. 
e If COMINIT is received then PXSERR.DIAG.X shall be set and 
no response (OOB signal) shall be sent to the device. 
e COMWAKE ignored. 


Software shall only place the port into this state when it believes 
that no device is connected on the port. In this mode, the HBA 
forces the Phy into a low power state without requesting a Slumber 
transition on the link. 
Oh 0>1 Spin-Up | HBA shall send COMRESET, begin initialization sequence 
This is the state where the HBA is performing data transfers. 

e COMINIT received, PXSERR.DIAG.X set, send COMRESET, 


Oh 0 Listen 


Oh 1 Normal nde ec hed 
begin initialization sequence 
e COMWAKE received, wake the link 

th 0 Illegal ene programs this condition, indeterminate results may 

HBA continuously transmits COMRESET. HBA does not listen for 
th 1 Reset COMINIT. The HBA may optionally set the PxSERR.DIAG.X bit if a 

COMINIT is received. 

1h > Oh 1 Initialize | Stop sending COMRESET, begin initialization sequence. 

4h N/A Off Off 


Software must only clear PxCMD.SUD if it believes that no device is attached. In Listen Mode 
(PXSCTL.DET = Oh and PxCMD.SUD = 0), the HBA Phy may enter a reduced power state, equivalent to 
the power consumed while in the Slumber power management state. The HBA Phy enters this reduced 
power state without negotiating a transition to Slumber on the link, as asking for a transition to Slumber 
when no device is attached will fail, and therefore the HBA Phy would stay in a high power state. To 
avoid this software should ensure that PxSSTS.DET = Oh indicating that no device is present before 
clearing PXCMD.SUD. 


10.9.2 Spin-Up Procedure (Informative) 


During initial system power-on in a system that supports staggered spin-up, software needs to spin up 
each attached device. In addition, when the system transitions from the S3 or greater system power 
management state back to SO, the attached drives will also need to be spun up. In order to spin up the 
devices attached to the HBA, software should perform the procedure outlined in section 10.1.1 for 
staggered spin-up. 


10.9.3 Preparing for Low Power System State (Informative) 


Before a system transitions to the S3 or greater power management state, the driver should prepare the 
drives in the system for a smooth transition to the low power state and eventually back to SO. Whena 
system transitions to state S3 or greater, the drive will cease having power applied. Since the drive loses 
power, when the drive is powered back on in the transition back to SO the drive will undergo another 
staggered spin-up process. 


Software should follow the procedure outlined below on each implemented port before the power 
management transition: 


1. Ifadrive is present, issue either the STANDBY or SLEEP command to the drive. 
2. Ifadrive is present, place the interface into Slumber by setting PxCMD.ICC = 6h. 


3. After the interface is no longer in the active power state as specified by PxSSTS.IPM, set 
PxSCTL.DET = 0h and PXCMD.SUD = Oh to enter listen mode. Note that PXSCTL.DET must be 
set to Oh before setting PXCMD.SUD to Oh. 
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This process ensures that staggered spin-up can be used on the system transition back to SO. 
10.9.4 When to Enter Listen Mode (Informative) 


Listen mode should be entered on a particular port when: 
e Staggered spin-up is supported on the platform 
e _Interlocked switch is not supported on this port 
e Cold presence detect is not supported on this port 
e No device is attached to this port 


In this case, listen mode should be entered to save power on the port while still allowing a hot plug 
insertion event to be detected via PxSERR.DIAG.X. Listen mode should also be entered to save power 
when a drive is present on a port and the system is about to enter a low power state, refer to section 
10.9.3. 


Listen mode should not be used if mechanical presence switch or cold presence detect is 
supported on the port. In this instance, the Phy for the port should be placed in the offline mode 
to save maximum power since any hot plug insertion can be detected using the mechanical 
presence switch or cold presence detect interrupts. 


10.10 Asynchronous Notification 


Asynchronous Notification is a feature in Serial ATA Il: Extensions to Serial ATA 1.0 revision 1.2. This 
feature allows an ATAPI device to send a signal to the host when media is inserted or removed and 
avoids polling the device for media changes. The signal sent to the host is a Set Device Bits FIS with the 
‘l (interrupt) and ‘N’ (notification) bits set to ‘1’. Refer to the Extension to Serial ATA 1.0a revision 1.2 
specification for more information on device behavior for asynchronous notification and how the device 
shows support for this feature. 


The HBA may support receipt of an asynchronous notification event via the Set Device Bits FIS for a 
directly attached device. To use asynchronous notification, software should set the PxIS.SDBS bit to 
enable interrupt notification on a Set Device Bits FIS. When accesses to the ATAPI device are idle, 
software should place the device in a low power state. When the device has a media change, the device 
will signal this to the host with a Set Device Bits FIS. In response to receiving a PxIS.SDBS interrupt on 
an idle port, the host should interrogate the device to determine the cause of the interrupt. 


10.10.1 Notifications from Devices Connected to a Port Multiplier 


Asynchronous Notification could also be used with a Port Multiplier, particularly when using command- 
based switching. A few examples of how this mechanism could be used include indicating media has 
been inserted in an ATAPI device connected to the Port Multiplier or indicating that a hot plug event has 
occurred on a Port Multiplier port. 


In order to utilize asynchronous notification behind a Port Multiplier, the HBA must support the 
SNotification register that latches the asynchronous notification events from up to 16 targets. The HBA 
indicates support for the SNotification register by setting CAP.SSNT to ‘1’. 


10.10.1.1 SNotification Operation 


When a FIS is received by the host controller, the first Dword of the FIS contains a 4 bit Port Multiplier 
Port (PM Port) field. The PM Port field indicates which port/target behind the Port Multiplier issued the FIS 
to the host. When a Set Device Bits FIS is received by the host controller and the ‘N’ (Notification) bit is 
set, the bit position in the SNotification register corresponding to the PM Port field is set. The host will set 
the PxIS.SDBS bit to “1” if the ‘I’ (Interrupt) bit is set in the Set Device Bits FIS. This will cause an 
interrupt to be generated if that interrupt is enabled. Note that when a PM is not present, the PM Port field 
in the Set Device Bits FIS will be Oh causing bit 0 of the SNotification register to be set. 


When using command-based switching, a received FIS is normally discarded if the PM Port 

field does not match the port currently being accessed. However, to support asynchronous 

notification from any port behind a Port Multiplier (including the control port), the bit in the SNotification 
register will be set and an Set Device Bits FIS interrupt will be generated (if enabled) even when the PM 
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Port field of a Set Device Bits FIS does not match the port/target currently being accessed if the ‘N’ 
(Notification) bit is set in the Set Device Bits FIS. If the ‘N’ bit is set and the PM port does not match the 
port currently being accessed, then PxIS.IPMS is not set, the FIS is discarded, and PXTFD and PxSACT 
are not updated based on the contents of the FIS. If the ‘N’ bit is set and the PM port does match the port 
currently being accessed, the Set Device Bits FIS is processed normally (including posting the FIS, 
updating PxTFD and PxSACT, etc). 


If the ‘N’ (Notification) bit is not set in the Set Device Bits FIS, then the Set Device Bits FIS received is 
handled according to normal processing for the Port Multiplier mode (command-based or FlS-based) that 
the HBA is operating in. 


10.11 Activity LED 


An HBA optionally drives an output pin that can be connected to an external LED based upon activity of 
the various ports in the HBA. The intended use of this LED is for desktop and mobile systems that 
contain only a single LED to indicate device activity. An HBA indicates support for this pin via CAP.SAL. 


The intent of this LED output is to replace the DASP functionality that is provided in parallel ATA systems. 
The DASP logic in the device would light the LED under the following scenarios: 
e During boot, software reset, or device reset: LED would be driven by the slave device on 
a cable (if present) to indicate slave presence. The LED would remain on until a 
command was written to the slave device, or 30 seconds, whichever comes first. 
e During normal operation, while the BSY bit was set in the task file for ATA commands. It 
may optionally be on for ATAPI commands (AOh and Ath). 


In AHCI, slave devices are not supported — every device is a master. Therefore, the first LED mechanism 
is not supported by an AHCI HBA. An HBA that supports legacy operation will have to consider this 
support if it supports master/slave emulation. 


To support the second mechanism of LED operation, the HBA shall drive the LED pin active if CAP.SAL 
is set, and: 

e = If (PxCl != Oh or PXSACT != Oh) and PXCMD.ATAPI = ‘0’. 

e = If (PxCl != Oh or PXSACT != Oh) and PXCMD.ATAPI = ‘1’ and PXCMD.DLAE = ‘1’, 


When PxCl and PxSACT are both cleared to Oh the LED shall be driven off. 
10.12 BIST 


BIST is entered when software builds a BIST FIS in the command list and sets CTBAz[B]. Once a BIST 
command is placed into the list, SW is not allowed to build any more commands until it clears PxCMD.ST. 


Details of how an HBA operates in the test mode are outside the scope of this specification. A series of 
vendor specific tests may be performed using vendor specific registers (such as those in the HBA’s PCl 
configuration space). The details of BIST are not defined in AHCI to allow vendors the freedom of 
constructing either very elaborate or very light testing schemes. 


The test mode is exited when system software clears PxCMD.ST and writes a value of 1h into 
PxSCTL.DET. Clearing PxCMD.ST shall put the DMA engines into an idle condition, and writing to 
PxSCTL.DET shall reset the interface. 


10.13 Index-Data Pair 


Index-Data Pair (IDP) provides host software with a mechanism whereby registers implemented in the 
AHCI’s memory mapped I/O space (> 1MB) can be read from or written to. On PC based platforms, host 
software (BIOS, Option ROMs, OSs) written to operate in ‘real-mode’ (8086 mode) is unable to access 
registers in a PCI function’s address space, if the address space is 1) memory mapped and 2) mapped 
above 1MB. This is problematic for host software running on an AHCI enabled system when: 


= An AHCI implementation does not support legacy access methods 


= An AHCI implementation supports legacy access mechanism and also supports > 4 devices 
(natively or via Port Multiplier) 
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The IDP mechanism allows host software to access all of the MMIO AHCI registers using indirect I/O 
addressing in lieu of direct memory mapped I/O (MMIO) access via the AHCI Base Address Register 
(ABAR). 


10.13.1 Rules/Restrictions 


While the IDP provides host software with full access to the AHCI’s MMIO registers, there are a few rules 
and restrictions that must be followed by both the hardware and host software implementations: 


1. When supported, the use of the Index-Data pair by host software shall not be gated by the setting 
of the GHC.AE (AHCI Enable); Index-Data pair shall be functional, regardless of the setting of the 
AHCI Enable register and shall allow host software full access to the AHCI HBA’s MMIO register 
space. However, host software is not permitted to initiate transactions to device(s) attached to 
any of the SATA ports implemented by the AHCI HBA, prior to setting the GHC.AE to ‘1’. Host 
software’s attempts to access devices attached to the AHCI HBA prior to setting GHC.AE to ‘1’ 
will result in indeterminate behavior. 


2. The Index-Data pair mechanism is intended for use by host software that does not support AHCI 
through the AHCI MMIO space. While it is not prohibited for host software (that provides native 
AHCI support - e.g. OS device driver) to use IDP, for performance and flexibility reasons, it is 
strongly recommended that such software not use IDP; rather the host software should be 
designed to use AHCI in a completely native fashion (via ABAR). Host software shall not alternate 
between IDP and MMIO access mechanism as this may result in indeterminate behavior. 


10.13.2 IDP Index Register Format 
The IDP Index register is a Dword (4 bytes) in length and has the following format: 


Bit Type Reset | Description 


31:nt1 RO Oh Reserved 


n:2 RW Oh IDP Index: This register selects the Dword offset of the memory 
mapped AHCI register to be accessed. The IDP Index should be 
sized such that it can access the entire ABAR register space for 
the particular implementation 


1:0 RO Oh Reserved 


10.13.3 IDP Data Register Format 


The IDP Data register is a Dword (4 bytes) in length. All register accesses to IDP Data are Dword 
granularity. IDP Data has the following format: 


Bit Type Reset Description 


31:00 RW n/a IDP Data: This register is a “window” through which data is read 
or written to the memory mapped register pointed to by the IDP 
Index register. Note that a physical register is not actually 
implemented as the data is actually stored in the memory 
mapped registers. 


Since this is not a physical register, the “default” value is the 
same as the default value of the register pointed to by IDP Index. 


It is the reading or writing of this register by host software that results in action by the AHCI hardware. 
Therefore, host software must ensure that the IDP Index register is properly setup prior to the reading or 
writing of this register. 


10.13.4 Access Mechanism 


The following pseudo-code provides an example of how host software designed to use IDP could be 
implemented to place the AHCI HBA in AHCI Enabled mode and then proceed to do other AHCI specific 
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operations. Note that this pseudo-code does not assume any particular instruction set and is provided for 
example only. 


// 
// Assumes that SW found the associated SATA capability ptr/structure and has computed/saved the 
// location of the index and data registers 


es 
Global DWORD IDP_Index // Computed Index register 
Global DWORD IDP Data // Computed Data register 
DWORD GHC // Temp storage for current Global HBA control settings 
Set IDP_Index, 4 // Offset 04h into AHCI MMIO space is where the Global HBA 
// vegister resides. We want to perform a read/modified write 
// instruction in order to set the AHCI Enable bit. 
Get GHC, IDP Data // The data register now has the contents of the Global HBA 
// Register. Save it for later restoration. 
Set IDP_ Data, GHC | 80000000 h // Program the HBA for AHCI mode. Note, because the Index 
// vegister is already program with the offset to the Global 
// HBA control register, we don’t need to reset it. 
// 


// AHCI HBA is now enabled for AHCI mode. Host software is now free to use the AHCI. As a further 
// example. Let’s clear the global interrupt status register. 


// 
Set IDP_Index, 8 // Global interrupt status is here 
Set IDP Data, FFFFFFFFh // clear the status register 
// do other stuff specific to this software 
// 


// This software is ready to terminate. Assumed that the software has cleaned up any status 
// registers, pending interrupts, etc and has placed the HBA in the condition it originally 
// found it. Set the AE bit back to what it was as the final step before termination 

Set IDP_Index, 4 

Set IDP_ Data, GHC // back to the way it was 


Exit (0) // exit 


10.13.5 Index-Data Pair Discovery 


Determining whether or not the AHCI HBA supports Index-Data Pair can be accomplished through an 
examination of the PCI configuration space. Software should search for the generic SATA capability 
pointer in the PCI capability list (see section 2.4), identified by capability identifier 12h. The generic SATA 
capability pointer identifies the location of the Index-Data Pair registers. For more information, refer to 
section 2.4 which outlines the generic SATA capability pointer as used in AHCI. Additional details are 
included in the PCI Engineering Change Notice entitled “Generic Capability Structure for SATA Host Bus 
Adapters”, available at www.pcisig.com. 
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11 Command Completion Coalescing 


Command Completion Coalescing (CCC) is a feature designed to reduce the interrupt and command 
completion overhead in a heavily loaded system. The feature enables the number of interrupts taken per 
completion to be reduced significantly, while ensuring a minimum quality of service for command 
completions. When a software specified number of commands have completed or a software specified 
timeout has expired, an interrupt is generated by hardware to allow software to process completed 
commands. This feature applies to all ports selected to be in the command completion coalescing set by 
software via the CCC_PORTS register. 


11.1 Command Completion Definition 


A command completion has occurred when either of the following occurs on a port selected for command 
coalescing: 


e (PxCl[x] transitions from ‘1’ to ‘0’) AND (PxSACT[x] = ‘0’) 
e PxSACT[x] transitions from ‘1’ to ‘0’ 


When a command completes the internal HBA variable, hCccComplete, is incremented by one. If 
multiple bits transition at the same time and meet one of the preceding criteria, hCccComplete is 
incremented once for each bit that satisfies the criteria. 


11.2 Timer Definition 


An HBA that implements the command completion coalescing shall have an internal timer, hCccTimer, 
that is decremented while there are commands outstanding on ports selected for command coalescing. 
Commands are outstanding when for any port selected for command coalescing, the value of PxCl or 
PxSACT is non-zero. hCccTimer is decremented by 1h every 1 millisecond (the resolution of the software 
specified timeout value). 


11.3 Selected Ports 


A subset of the implemented ports, as defined by the Ports Implemented (Pl) register, may be specified 
for use with the command completion coalescing feature. The subset is defined by the bit-significant 
register CCC_PORTS. Ifa bit is set to ‘1’ in CCC_PORTS and the same bit is also set to ‘1’ in Pl, then 
that port is selected to be included in command completion coalescing. 


The CCC_PORTS value may be updated at any time by software. However, if there are outstanding 
commands on any ports at the time CCC_PORTS is updated, the HBA may not immediately adjust to 
ports that have just been selected or deselected. For example, if a command is in progress on a 
particular port and the command is about to complete near the same moment that CCC_PORTS is 
updated to newly select this port, the HBA may not increment hCccComplete. An updated CCC_PORTS 
value is guaranteed to be in effect within 1 millisecond of the write to the CCC_PORTS register. 


If a port is currently selected for command completion coalescing and an error occurs that requires 
PxCMD.ST to be cleared to ‘0’, software shall remove the affected port from the selected ports for 
command completion coalescing prior to clearing PXCMD.ST to ‘0’. 


11.4 Interrupt Definition 


The command coalescing completion interrupt, called the ‘CCC interrupt’, is generated on any of the 
following conditions: 
e hCccComplete is greater than or equal to the value specified by software in CCC_CTL.CC and 
CCC_CTL.CC != 0. 
e hCccTimer is decremented to Oh. (The interrupt is generated on the decrement to Oh, not the 
decrement from Oh to -1.) 
e hCccComplete is incremented and there are no more commands outstanding on the selected 
ports for command completion coalescing and CCC_CTL.CC != 0. 
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When the CCC interrupt is generated, hCccComplete is reset to Oh and hCccTimer is reset to the 
software specified timeout value in CCC_CTL.TV. If commands complete on the same cycle that 
hCccComplete is to be reset to Oh, the final value of hCccComplete shall be Oh after that cycle. These 
additional completions are “aggregated” into the current CCC interrupt that is being generated. The CCC 
interrupt utilizes the Interrupt Status (IS) register bit specified in CCC_CTL.INT. The CCC interrupt shall 
also use the MSI vector that corresponds to CCC_CTL.INT. The CCC interrupt corresponds to the 
interrupt for an unimplemented port on the controller. 


11.5 Enable and Disable Behavior 


The CCC feature is only in use when CCC_CTL.EN is set to ‘1’. If CCC_CTL.EN is set to ‘0’, no CCC 
interrupts shall be generated. 


On transition of CCC_CTL.EN from ‘0’ to ‘1’, the following shall occur: 


HBA uses the Timeout Value specified in the CCC_CTL.TV field 

HBA uses the Command Completions value specified in the CCC_CTL.CC field 
hCccTimer is reset to CC_CTL.TV 

hCccComplete is reset to Oh 


Software shall not modify the values in CCC_CTL.TV nor CCC_CTL.CC while CCC_CTL.EN is set to ‘1’. 
Writing these values while command completion coalescing is enabled will result in indeterminate 
behavior. 


11.6 Software Behavior 
11.6.1 Initialization 


To initialize use of the command completion coalescing feature for a set of ports, software needs to 
perform several steps. 


e Software should turn off per port interrupts for the D2H Register FIS and the Set Device Bits FIS 
(clear PXIE.DHRE and PxIE.SDBE to ‘0’) for each port that will be part of command completion 
coalescing. 

e Software should turn on per port interrupts for hot plug and error events. These events should be 
handled on a per port basis. 

e Software should ensure that CCC_CTL.EN is cleared to ‘0’. 

e Software should set CCC_PORTS to the desired value based on which ports should be part of 
the command completion coalescing set. Note that software shall only set a bit in the 
CCC_PORTS register if the corresponding bit is set in the Ports Implemented (PI) register. 

e Software should set CCC_CTL.TV and CCC_CTL.CC to the desired values. 

e Software should enable command completion coalescing by setting CCC_CTL.EN to ‘1’. 


After enabling command completion coalescing, software should check if any commands have completed 
on any port while performing the initialization. Software can do this by checking the PxCl (non-queued 
commands) or PxSACT (native queued commands) register for each port whose corresponding bit is set 
to ‘1’ in CCC_PORTS. 


11.6.2 Errors and Hot Plug Events 


Note that error and hot plug events are handled on a per port basis, so the corresponding per port enable 
(PxIE) bits are set to ‘1’. When an error or hot plug event occurs, software should remove that port from 
the command completion coalescing set by updated CCC_PORTS. This change will take effect within 1 
millisecond. Then software should service the error or hot plug event. After the port is again functional, 
software may add the port to the command completion coalescing set by updating CCC_PORTS. 
CCC_CTL.EN may be set to ‘1’ when a port is added to or removed from the command completion 
coalescing set. 
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11.6.3 CCC Interrupt Handling 
Upon detecting that a CCC interrupt has occurred, software should perform the following steps in order. 


e Software should clear the CCC interrupt by writing a ‘1’ to bit location IS.IPS[CCC_CTL.INT]. 
Note that this step is not required if multiple MSI messaging is in use. 

e Software should query the PxCl (for non-queuing commands) and PxSACT (for native queued 
commands) registers to determine the commands that have been completed. 

e Software should complete commands finished commands to the OS that were identified in the 
previous step. 


11.6.4 Updating Timeout Value or Number of Command Completions 


Software during the course of operation may choose to update the timeout value or the number of 
command completions required before causing the CCC interrupt based on implementation specific 
algorithms. To update these values, software should perform the following procedure: 
e Software should clear CCC_CTL.EN to ‘0’ 
e Software should update CCC_CTL.TV (timeout value) and CCC_CTL.CC (number of command 
completions) as desired 
e Software should set CCC_CTL.EN to ‘1’ 


Software shall not modify the values in CCC_CTL.TV nor CCC_CTL.CC while CCC_CTL.EN is set to ‘1’. 
Writing these values while command completion coalescing is enabled will result in indeterminate 
behavior. 


While command completion coalescing was disabled, additional commands may have completed on 
those ports that are part of the command completion coalescing set. After re-enabling command 
completion coalescing, software should check if any commands have completed on any port while 
performing the initialization. Software can do this by checking the PxCl (non-queued commands) or 
PxSACT (native queued commands) register for each port whose corresponding bit is set to ‘1’ in 
CCC_PORTS. 


11.7 Example (Informative) 


This section describes an example scenario of commands completing on multiple ports when command 
completion coalescing is used. This example is meant to illustrate core concepts of command completion 
coalescing. 


Software selects ports 2, 4, and 5 to be in the command completion set by writing CCC_PORTS = 
00000032h. The CCC_CTL.TV value is set by software to 5000 to ensure that a CCC interrupt is 
generated at least every 5 seconds to ensure that completed commands are not timed out at a higher 
level by the OS. The CCC_CTL.CC value is set to 5 by software to cause a CCC interrupt after 5 total 
commands have completed among ports 2, 4, and 5. Software has selected the value of 5 based on the 
current amount of traffic being seen on ports 2, 4, and 5 and based on quality of service requirements. 
After setting the CCC_CTL.TV and CCC_CTL.CC values appropriately, software enables CCC by setting 
CCC_CTL.EN to ‘1’. 


Software receives three commands to issue for port 2. These commands are issued in a non-queued 
fashion and the resulting P2CI value is 00000015h (commands are issued in slots 0, 2, and 4) and 
P2SACT is Oh. Software receives two commands to issue for port 5. These commands are issued as 
NCQ commands and the resulting PSSACT value is 00010100h (commands are issued with tags 8 and 
16). At this point, hCccTimer has decremented to 4700 (300 milliseconds have elapsed since 
CCC_CTL.EN was set to ‘1’) and hCccComplete is still Oh. 


The drive attached to port 2 completes command 0 and P2CI is updated to be 00000014h. When bit 0 of 
P2Cl transitions from ‘1’ to ‘0’ the hCccComplete variable will be incremented to 1h since P2SACT bit 0 is 
also cleared to ‘0’. Next the drive attached to port 5 completes both commands and P5SACT is updated 
to be Oh. When bits 8 and 16 transition from ‘1’ to ‘0’, hCccComplete will be incremented by 2 to a value 
of 3h. The hCccComplete variable is incremented once for each command that completes; note that 
when PxSACT bits transition from ‘1’ to ‘0’ there is no qualification on the values of the PxCl register for 
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incrementing hCccComplete. At this point, hCccTimer has decremented to 4200 and hCccComplete is 
3h. 


Software receives three more commands for port 5. These commands are issued as NCQ commands 
and the resulting PSSACT value is 00700000h (commands are issued with tags 20, 21, and 22). At this 
point, no more commands have been completed so hCccComplete remains set to 3h while hCccTimer 
has continued to decrement to 4000. 


The drive attached to port 5 completes the command with tag 22. P5SACT is updated to be 00300000h. 
When bit 22 transitions from ‘1’ to ‘0’, hCccComplete will be incremented by 1 to a value of 4h. 


The drive attached to port 2 completes the command in slot 2. P2Cl is updated to be 00000010h. When 
bit 2 transitions from ‘1’ to ‘0’, hCccComplete will be incremented by 1 to a value of 5h since P2SACT bit 
2 is also cleared to ‘0’. At his point, hCccTimer has decremented to 3500 and hCccComplete is 5h. 


When hCccComplete is incremented to 5h (or greater if multiple commands had completed in the same 
cycle), the hardware will recognize that the number of commands completed has reached the 
CCC_CTL.CC threshold. Hardware will then clear hCccComplete to Oh, set hCccTimer to CCC_CTL.TV, 
and then set IS.IPS[CCC_CTL.INT] to ‘1’. If interrupts are enabled (GHC.IE = ‘1’), the HBA will then 
generate an interrupt to software. 


After this interrupt is generated to software, the process continues and hCccComplete will start 
incrementing again based on completions, while hCccTimer will continue to decrement as time elapses. 
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12 Enclosure Management 


Enclosure management is a mechanism by which the storage driver can monitor and control auxiliary 
services in a drive enclosure. The most common task is controlling LEDs that show per drive status 
information. LEDs per drive could include device activity, fault (to indicate a failure), and locate (to show 
an operator the bay to remove/insert a drive from/into). Note that device activity indications may be 
provided by the device itself. Other examples of enclosure management features include: power supply 
control and monitoring, temperature monitoring, and presence detection. 


There are three common enclosure management protocols in use: SAF-TE, SES-2 and SGPIO. 
References to these specifications are in section 1.9. These protocols are typically used between the 
host controller (or Port Multiplier) and an enclosure processor that controls/monitors the sensors/LEDs 
within the enclosure. 


To use the SAF-TE or SES-2 protocols, the HBA must communicate with a storage enclosure processor 
(SEP) that supports the desired protocol. The physical bus that attaches the HBA to the SEP is I?C; note 
that this requires additional pins to be added to the HBA. The IPMI protocol is used over °C to 
communicate with the SEP. The Serial ATA Il: Extensions to Serial ATA 1.0a revision 1.2 specification 
contains details on how SAF-TE and SES-2 packets are exchanged with a SEP. 


To use the SGPIO protocol, the HBA communicates with an SGPIO target. The 4 pin bus that attaches 
the HBA to the SGPIO target is defined in the SGPIO specification. 


12.1 Mechanism 


Enclosure management involves sending messages that control features of the enclosure or receiving 
messages that provide status for the enclosure. The messages for this function are stored after the 
normal registers in the AHCI BAR, at an implementation specific offset from the beginning of the AHCI 
BAR as specified by the EM_LOC global register. 
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Figure 23: Enclosure Management Buffer Location 
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Software creates messages for transmission in the enclosure management message buffer. Software 
then writes a register to cause hardware to transmit the message or take appropriate action based on the 
message content. Message types that software can create include LED, SAF-TE, SES-2, and SGPIO 
messages. Software shall only create messages for message types that hardware indicates support for. 


Software shall not change the contents of the message buffer after it has requested that hardware 
transmit that buffer until hardware acknowledges that the transmission is complete. 


12.2 Message Format 


Messages shall be constructed with a one Dword header that describes the message to be sent followed 
by the actual message contents. The first Dword shall be constructed as follows: 


| Bit |Description °° 
31:28 
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Message Type (MTYPE): Specifies the type of the message. 


The message types are: 

Oh —- LED 

th — SAF-TE 

2h — SES-2 

3h — SGPIO (register based interface) 

All other values reserved 
Data Size (DSIZE): Specifies the data size in bytes. If the message (enclosure services 
commanda) has a data buffer that is associated with it that is transferred, the size of that 
data buffer is specified in this field. If there is no separate data buffer, this field shall 
have a value of ‘0’. The data directly follows the message in the message buffer. 
Message Size (MSIZE): Specifies the size of the message in bytes. The message size 
does not include the one Dword header. A value of ‘0’ is invalid. 


The SAF-TE, SES-2, and SGPIO message formats are defined in the corresponding specifications, 
respectively. The LED message type is defined in section 12.2.1. 


12.2.1 LED message type 


The LED message type specifies the status of up to three LEDs. Typically, the usage for these LEDs is 
activity, fault, and locate. Not all implementations necessarily contain all LEDs (for example, some 
implementations may not have a locate LED). The message identifies the HBA port number and the Port 
Multiplier port number that the slot status applies to. If a Port Multiplier is not in use with a particular 
device, the Port Multiplier port number shall be ‘0’. The format of the LED message type is defined in the 
following table. The LEDs shall retain their state until there is a following update for that particular slot. 
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Value (VAL): This field describes the state of each LED for a particular location. There 
are three LEDs that may be supported by the HBA. Each LED has 3 bits of control. 
LED values are: 

000b — LED shall be off 

001b — LED shall be solid on as perceived by human eye 

010b — Reserved 

011b — Reserved 

100b — Vendor specific 

101b — Vendor specific 

110b — Vendor specific 

111b — Vendor specific 

All other values reserved 


The LED bit locations are: 

Bits 2:0 — Activity LED (may be driven by hardware) 

Bits 5:3 — Vendor Specific LED (e.g. locate) 

Bits 8:6 — Vendor Specific LED (e.g. fault) 

Bits 15:9 — Reserved 
Port Multiplier Information: Specifies slot specific information related to Port Multiplier. 
Bits 3:0 specify the Port Multiplier port number for the slot that requires the status 
update. If a Port Multiplier is not attached to the device in the affected slot, the Port 
Multiplier port number shall be Oh. Bits 7:4 are reserved. 
HBA Information: Specifies slot specific information related to the HBA. 


Bits 4:0 — HBA port number for the slot that requires the status update. 

Bit 5 — If set to ‘1’, Value is a vendor specific message that applies to the entire 
enclosure. When set to ‘1’, bits 4:0 of HBA Information is ignored and not used. 
If cleared to ‘0’, Value applies to the port specified in bits 4:0. 

Bits 7:6 — Reserved 


12.2.2 SAF-TE message type 


SAF-TE is an enclosure services protocol that uses the SCSI command set as a basis. The two primary 
SCSI commands used for SAF-TE are READ BUFFER and WRITE BUFFER. Each of these commands 
has several subcommands defined for controlling the SEP and monitoring status of the enclosure. 


The SAF-TE message type sent to a storage enclosure processor (SEP) is in the form of a SCSI CDB 
since each SAF-TE message is a SCSI command. Each CDB begins with a one byte SCSI opcode. 


Some SAF-TE commands have a data buffer that is associated with the command. For example, WRITE 
BUFFER has a data buffer that is written to the SEP to instruct the SEP on the exact actions to be taken. 
This data shall immediately follow the CDB of the associated command in the message buffer. The size 
of the CDB for the SAF-TE command is specified in the MSIZE field in the message header. The size of 
the data buffer for the SAF-TE command is specified in the DSIZE field in the message header. 


For more information on SAF-TE commands and associated subcommands, see the SAF-TE reference. 
12.2.3 SES-2 message type 


SES-2 is an enclosure services protocol that uses the SCSI command set as a basis. The two primary 
SCSI commands used for SES-2 are RECEIVE DIAGNOSTIC RESULTS and SEND DIAGNOSTIC. 
Each of these commands has associate diagnostic parameter and diagnostic status formats for 
controlling the SEP and monitoring status of the enclosure. 


The SES-2 message type sent to a storage enclosure processor (SEP) is in the form of a SCSI CDB 
since each SES-2 message is a SCSI command. Each CDB begins with a one byte SCSI opcode. 


Some SES-2 commands have a data buffer that is associated with the command. For example, SEND 
DIAGNOSTIC has a set of diagnostic parameters that are written to the SEP to instruct the SEP on the 
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exact actions to be taken. This data shall immediately follow the CDB of the associated command in the 
message buffer. The size of the CDB for the SES-2 command is specified in the MSIZE field in the 
message header. The size of the data buffer for the SES-2 command is specified in the DSIZE field in 
the message header. 


For more information on SES-2 commands and diagnostic parameters/formats, see the SES-2 reference. 
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13 Informative Appendix 
13.1 Port Selector Support 


A Port Selector may be attached to an HBA port. To control the Port Selector with protocol-based port 
selection, software should issue COMRESET bursts at the appropriate intervals by using the PxSCTL 
register appropriately. Controlling the Port Selector with side-band port selection is beyond the scope of 
this specification. 
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